函数工作流 FunctionGraph
函数工作流 FunctionGraph
- 最新动态
- 功能总览
- 产品介绍
- 计费说明
- 快速入门
- 用户指南
-
最佳实践
- FunctionGraph最佳实践汇总
-
数据处理类实践
- 使用FunctionGraph函数对OBS中的图片进行压缩
- 使用FunctionGraph函数为OBS中的图片打水印
- 使用FunctionGraph函数对DIS数据进行格式转换并存储到CloudTable
- 使用FunctionGraph函数实现通过API方式上传文件
- 使用FunctionGraph函数对IoTDA中的设备坐标数据进行转换
- 使用FunctionGraph函数对OBS中的文件进行加解密
- 使用FunctionGraph函数识别LTS中的异常业务日志并存储到OBS
- 使用FunctionGraph函数对LTS中的日志进行实时过滤
- 使用FunctionGraph函数流对OBS中的图片进行旋转
- 使用FunctionGraph函数流对图片进行压缩和打水印
- 功能应用类实践
- 函数构建类实践
- 开发指南
- API参考
- SDK参考
- 场景代码示例
-
常见问题
-
产品咨询
- 使用FunctionGraph是否需要开通计算、存储、网络等服务?
- 使用FunctionGraph开发程序之后是否需要部署?
- FunctionGraph为函数分配的磁盘空间有多少?
- 是否支持在函数中启动TCP的监听端口,通过EIP接收外部发送过来的TCP请求?
- 函数发起HTTP请求的源地址如何获取?
- FunctionGraph是否支持对上传的zip文件进行反编译?
- FunctionGraph的函数是否支持功能扩展?
- FunctionGraph中的代码是如何隔离的?
- 函数常规信息中的“应用”如何理解?
- 用户需要为函数的冷启动时间付费吗?
- 函数计费中的调用次数,是某一账号下在不同region的所有函数的调用次数总和吗?
- Python语言的函数从V1版本迁移到V2版本时需注意哪些兼容性问题?
- FunctionGraph函数支持哪些编程语言?
- 创建函数
-
配置函数
- 能否在函数环境变量中存储敏感信息?
- FunctionGraph的函数如何读写上传的文件?
- 为函数挂载文件系统时,报“failed to mount exist system path”
- FunctionGraph如何实现域名解析?
- FunctionGraph如何通过域名访问专享版APIG中注册的接口?
- FunctionGraph函数通过域名访问APIG中注册的接口时,报域名无法解析?
- 使用定制运行时语言的函数能操作哪些目录?
- FunctionGraph的函数支持哪些中文字体?
- 能否在函数代码中使用线程和进程?
- 函数如何访问MySQL数据库?
- 函数无法通过VPC连接对应的Redis?
- 如何读取函数的请求头?
- Python语言的函数中,中文注释报乱码错误
-
调用函数
- FunctionGraph的函数执行需要多长时间?
- FunctionGraph的函数执行包含了哪些过程?
- FunctionGraph函数长时间不执行时,相关的实例会如何处理?
- 如何获取函数运行过程中的内存使用量信息?
- 为什么首次调用函数时速度会比较慢?
- 为什么函数实际使用内存大于预估内存,甚至触发内存溢出OOM?
- 函数执行失败返回“runtime memory limit exceeded”时,如何查看内存占用大小?
- 自定义镜像函数执行失败报“CrashLoopBackOff”
- 同步调用函数时,未收到调用响应的可能原因?
- 函数中os.system("command &")命令的执行日志未采集,应如何处理?
- 函数执行超时的可能原因有哪些?
- 使用APIG触发器调用一个返回String的FunctionGraph函数时,报500错误
- Python2.7在执行reload(sys)后无法通过print打印日志
- 运行函数时报错error while loading shared libraries时如何处理?
- 配置触发器
- 配置依赖包
-
产品咨询
- 视频帮助
- 文档下载
- 通用参考
更新时间:2025-02-08 GMT+08:00
链接复制成功!
配置函数的异步调用策略
在异步调用函数的场景下,FunctionGraph会将请求排队,不等待函数的执行结果,直接向客户端返回响应,这种情况下客户端无法实时感知函数的执行结果。如果需要设置异步请求失败重试或者获取异步请求的结果通知,可以通过设置异步配置实现。
- 失败重试:用户代码异常造成的失败,FunctionGraph默认不重试。如果函数中有需要重试的场景,例如调用三方服务经常失败,可配置重试提升成功率。
- 结果通知:FunctionGraph可以将异步函数的执行结果传递给下游服务做进一步处理。例如把执行失败信息保存到OBS,用于后续分析失败原因,或者把执行成功信息推送到DIS或再次触发函数做处理等。
约束与限制
- 若修改异步配置时报“用户权限不足”,请添加“FunctionGraph Administrator”权限,具体操作方法请参见创建用户并授权使用FunctionGraph。
- 使用异步配置通知目标服务时,需配置具有目标服务操作权限的函数委托。
- 使用异步配置通知目标服务时,请务必保证不要出现循环调用的情况。
例如:函数A配置了成功调用时的异步通知目标为函数B,函数B配置了成功调用时的异步通知目标为函数A,当异步触发函数A并且执行成功后,则可能出现A>B>A......循环调用的情况。
- 使用异步配置通知分布式消息服务(RocketMQ)时,需要函数配置VPC且与通知的RocketMQ实例在同一个VPC中。同时,需要确保RocketMQ实例所在的安全组入方向规则已放通实例的连接端口,否则无法通知消息。(当前处于公测阶段,仅支持华东-上海一。)
- 使用异步调用的函数,返回值的大小不能超过256KB,否则会返回空值。
配置异步调用策略
- 登录函数工作流控制台,在左侧的导航栏选择“函数 > 函数列表”。
- 单击函数的名称,进入函数详情页。
- 在“设置”页签下选择“异步配置”。
- 在异步配置页面,单击“配置异步调用”,编辑异步配置信息。
图1 填写配置参数
表1 异步配置参数说明 参数
说明
异步策略配置
- 最大重试次数:异步调用失败后最大重试次数,默认为1次,取值范围:0-3。
- 消息最大有效期(s):消息最大存活时长,取值范围:1-86400秒。
成功时通知
目标服务:函数执行成功时发送通知到以下目标服务。
失败时通知
目标服务:函数执行失败时发送通知到以下目标服务。
- 函数工作流(FunctionGraph)
- 函数名称:选择接收通知消息的函数名称。
- 版本/别名:选择函数对应的版本或别名。
- 对象存储服务(OBS)
- 目标桶目录:选择存放通知消息的OBS桶路径。
- 对象前缀目录:输入对象前缀目录,以筛选通知消息要存放的对象文件。
- 对象过期时间(天):过期后的对象会被OBS服务端自动清理。单位:天,取值范围:0-365,0表示不过期。
- 数据接入服务(DIS)
- 消息通知服务(SMN)
- 分布式消息服务 RocketMQ版(RocketMQ)(当前处于公测阶段,仅支持华东-上海一。)
- 实例:选择接收通知消息的RocketMQ实例。
- Topic:选择接收通知消息的Topic。
- 单击“确定”保存异步配置。
通知消息结构说明
FunctionGraph向目标发送异步调用通知的消息示例如下所示。
{ "timestamp": "2020-08-20T12:00:00.000Z+08:00", "request_context": { "request_id": "1167bf8c-87b0-43ab-8f5f-26b16c64f252", "function_urn": "urn:fss:xx-xxxx-x:xxxxxxx:function:xxxx:xxxx:latest", "condition": "", "approximate_invoke_count": 0 }, "request_payload": "", "response_context": { "status_code": 200, "function_error": "" }, "response_payload": "hello world!" }
参数 |
说明 |
---|---|
timestamp |
函数开始执行的时间。 |
request_context |
请求上下文。 |
request_context.request_id |
异步调用的请求ID。 |
request_context. function_urn |
异步执行的函数URN。 |
request_context.condition |
调用错误类别。 |
request_context. approximate_invoke_count |
异步调用的执行次数。当该值大于1时,说明函数的执行进行了重试。 |
request_payload |
请求函数的原始负载。 |
response_context |
返回上下文。 |
response_context.statusCode |
调用函数的系统返回码。当该返回码不为200时,说明出现了系统错误。 |
response_context.function_error |
调用错误信息。 |
response_payload |
执行函数返回的原始负载。 |
父主题: 管理函数