函数触发
invoke
命令是对线上函数进行调用/触发的命令。
命令解析
当执行命令invoke -h
/invoke --help
命令时,可以获取帮助文档。
参数解析
参数全称 | 参数缩写 | Yaml 模式下必填 | Cli 模式下必填 | 参数含义 |
---|---|---|---|---|
region | - | 选填 | 必填 | 地域名称,取值范围参见函数计算开服地域 |
function-name | - | 选填 | 必填 | 函数名 |
qualifier | - | 选填 | 选填 | 指定调用的版本或者别名, 默认为 LATEST |
timeout | - | 选填 | 选填 | 客户端调用时间 |
event | e | 选填 | 选填 | 事件 |
event-file | f | 选填 | 选填 | 事件文件 |
invocation-type | - | 选填 | 选填 | 调用类型,取值范围:Async, Sync ,默认:Sync |
async-task-id | - | 选填 | 选填 | 有状态的异步调用自定任务id, 仅 invocation-type 为 Async 有效 |
当前命令还支持部分全局参数(例如
-a/--access
,--debug
等),详情可参考 Serverless Devs 全局参数文档
操作案例
- 有资源描述文件(Yaml)时,可以直接执行
s invoke
进行线上函数的调用; - 纯命令行形式(在没有资源描述 Yaml 文件时),需要指定函数所在地区以及函数名等,例如
s cli fc3 invoke -e "payload" --region cn-hangzhou --function-name start-python -a default
上述命令的执行结果示例:
注意事项
在进行调用时,如果需要指定相对应的事件,例如 oss 的事件,cdn 的事件…这些事件的格式,可以参考 event-template
此时,可以利用该路径的模板(可以额外进行修改)触发函数,例如:s invoke --event-file event-template/oss.json
权限与策略说明
-
最大权限:
AliyunFCInvocationAccess
或者AliyunFCFullAccess
-
最小权限: