- 最新动态
- 功能总览
- 产品介绍
- 计费说明
- 快速入门
- 用户指南
-
最佳实践
- 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函数长时间不执行时,相关的实例会如何处理?
- 如何获取函数运行过程中的内存使用量信息?
- 为什么首次调用函数时速度会比较慢?
- 函数执行失败返回“runtime memory limit exceeded”时,如何查看内存占用大小?
- 自定义镜像函数执行失败报“CrashLoopBackOff”
- 同步调用函数时,未收到调用响应的可能原因?
- 函数中os.system("command &")命令的执行日志未采集,应如何处理?
- 函数执行超时的可能原因有哪些?
- 使用APIG触发器调用一个返回String的FunctionGraph函数时,报500错误
- Python2.7在执行reload(sys)后无法通过print打印日志
- 运行函数时报错error while loading shared libraries时如何处理?
- 配置触发器
- 配置依赖包
-
产品咨询
- 视频帮助
- 文档下载
- 通用参考
链接复制成功!
创建函数流
函数流是一个面向无服务器计算领域,编排无服务器分布式应用的工作流服务。基于该服务,用户可以通过Low Code以及可视化的方式将多个独立的无服务器函数用顺序、分支、并行等方式轻松编排成一个完整的应用,并提供监控和管理平台,用于诊断和调试应用。
本章节主要介绍如何创建函数流任务和编排函数流任务。您可以根据实际业务场景来创建标准函数流或快速函数流。
- 标准模式面向普通的业务场景,支持长时间任务,支持执行历史持久化和查询,只支持异步调用,在函数流运行记录页面查询执行结果。
- 快速模式面向业务执行时长较短,需要极致性能的场景,只支持流程执行时长低于5分钟的场景,不支持执行历史持久化(比如不支持查询执行节点的历史信息),支持同步和异步调用。通过同步执行函数流接口进行函数流的同步执行,接口直接返回函数流执行结果,同时日志页面查看上报到LTS的函数流执行日志。
说明:
快速函数流限时免费,欢迎体验!
约束与限制
当前仅“华北-北京四、华东-上海二、华南-广州、华东-上海一、亚太-新加坡”区域支持函数流功能。
创建函数流
操作步骤
- 登录函数工作流控制台,左侧导航栏单击“函数流”。
- 单击“创建标准函数流”或“创建快速函数流”,进入新建函数流编排页面。
- 在函数流编排区域,通过拖拽组件进行流程编排,详情请参见函数流组件配置说明。
设计的函数流必须是一个有向无环图,从开始节点出发,开始节点后续必须且只能连接一个节点(除了异常处理和结束节点);流程必须在某一个节点结束,结束流程有两种形式:
- 流程中存在的节点没有任何后继节点,且后续节点非条件分支,并行分支或开始节点。
- 流程中存在结束节点,且结束节点后续无其他节点。
- 流程中的所有节点参数配置完成后,单击右上角的“保存”,进行参数配置,最后单击“确定”。
表1 配置信息
参数
说明
名称
输入函数流名称。
企业项目
选择企业项目。
日志记录
创建快速函数流,保存时需要选择此参数。
- ALL:为所有事件启用日志记录。
- ERROR:仅启用错误日志记录。
- NONE:关闭日志记录。
合并参数
将上一个节点的输出与下一个节点的输入合并为输入。
支持返回流式数据
创建快速函数流时可配置此参数。开启后,函数流执行支持返回流式数据,可参见流式文件处理。
需函数流中函数节点的代码调用流式数据接口。
描述
输入函数流的简要描述。
表达式说明
函数流的异常处理控制器组件中配置“重试条件(JSONPath)”和条件分支控制器组件中“输入过滤表达式/输出过滤表达式”的JSONPath表达式结构为[JsonPath] + [逻辑运算符] + [对比数据],如示例:$.age >= 20。
操作符 |
是否支持 |
说明 |
---|---|---|
$ |
是 |
执行查询的root,所有正则表达式由此启动。 |
@ |
是 |
过滤正在处理的当前位置。 |
. |
是 |
子节点。 |
[ (, )] |
是 |
数组索引。 |
[start:end] |
是 |
数组切片运算符。 |
[?()] |
是 |
过滤表达式, 表达式必须计算为布尔值。 |
{
"fruits": [ "apple", "orange", "pear" ],
"vegetables": [{
"veggieName": "potato",
"veggieLike": true
},
{
"veggieName": "broccoli",
"veggieLike": false
}]
}
运算符说明
使用以下数据作为例子中的输入参数:
{
"name" : "apple",
"weight": 13.4,
"type": [3,4,6,8],
"obj": {
"a" : 1
}
}
符号 |
作用 |
例子 |
返回值 |
备注 |
---|---|---|---|---|
== |
相等 |
$.name == 'apple' |
true |
支持的数据类型包括:int,float,string,bool,nil |
!= |
不等 |
$.name != 'apple' |
false |
支持的数据类型包括:int,float,string,bool,nil |
< |
小于 |
$.weight < 12 |
false |
只支持数字类型 |
> |
大于 |
$.weight > 12 |
true |
只支持数字类型 |
<= |
小于等于 |
$.weight <= 13.4 |
true |
只支持数字类型 |
>= |
大于等于 |
$.weight >= 13.4 |
true |
只支持数字类型 |
'*' |
通配符 |
$.weight == '*' |
true |
只支持在== 比较中使用 |
|| |
或 |
$.name == 'apple' || $.weight < 12 |
true |
支持使用()的复杂与或逻辑 |
&& |
且 |
$.name == 'apple' && $.weight < 12 |
false |
支持使用()的复杂与或逻辑 |
- 字符串格式常量需要使用''包含,例如:'apple'。
- jsonpath表达式中不能出现上述保留字符'=', '!=', '<', '>', '|', '&'。