- 最新动态
- 功能总览
- 产品介绍
- 计费说明
- 快速入门
- 用户指南
-
最佳实践
- 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时如何处理?
- 配置触发器
- 配置依赖包
-
产品咨询
- 视频帮助
- 文档下载
- 通用参考
链接复制成功!
使用TIMER定时触发器
本节介绍如何通过函数工作流控制台创建定时触发器,使用TIMER的计划事件功能,实现按照设置的频率或指定Cron表达式,定期触发函数运行。
关于定时触发器事件源的具体介绍,请参见支持的事件源。
前提条件
已创建函数,创建过程请参见创建函数。
创建定时触发器
- 登录函数工作流控制台,在左侧的导航栏选择“函数 > 函数列表”。
- 选择待配置的函数,单击进入函数详情页。
- 如图1所示,选择“设置 > 触发器”,单击“创建触发器”,弹出“创建触发器”对话框。
- 配置以下参数。
表1 定时触发器参数说明 参数
说明
取值样例
触发器类型
必选参数。
选择“定时触发器 (TIMER)”。
定时触发器 (TIMER)
定时器名称
必选参数。
自定义的定时器名称。支持字母、数字、下划线和中划线,必须以字母开头,且长度不能超过64个字符。
Timer-fg
触发规则
必选参数。
触发器的触发规则,可选择使用“固定频率”或“Cron表达式”。
- 固定频率:固定时间间隔触发函数,该类型下支持配置单位为分、时、天,每种类型仅支持整数配置,其中分钟支持范围(0,60],小时支持范围(0,24],天支持范围(0,30]。
- Cron表达式:设置更为复杂的函数执行计划,例如:周一到周五上午08:30:00执行函数等,具体请参见Cron表达式规则。
固定频率
3分钟
是否开启
必选参数。
是否开启定时触发器。
开启
附加信息
可选参数。
如果用户配置了触发事件,会将该事件填写到TIMER事件源的“user_event”字段,详情请参见支持的事件源。
-
- 单击“确定”,完成定时触发器的创建。
查看函数运行结果
函数的定时触发器创建以后,每隔一分钟执行一次函数,可以在函数详情页中查看函数运行日志。
- 返回函数工作流控制台,在左侧的导航栏选择“函数 > 函数列表”。
- 选择“函数”,单击函数名称进入函数详情页。
- 选择“监控 > 日志”,查询函数运行日志。
Cron表达式规则
- @every格式
@every NUnit,其中N表示一个正整数,Unit可以为ns, µs, ms, s, m, h,表示每隔N个Unit时间触发一次函数如表2所示。
- 标准Cron表达式
Cron表达式格式要求“秒 分 时 日 月 周(可选)”,每个字段间以空格隔开,其中各字段说明如表3所示。
表3 Cron表达式字段说明 字段
说明
取值范围
允许的特殊字符
CRON_TZ
可选。不设置则默认使用region所在时区。
-
-
秒
必选
0-59
, - * /
分钟
必选
0-59
, - * /
时
必选
0-23
, - * /
日(Day of month)
必选
1-31
, - * ? /
月
必选
1-12或者Jan-Dec(英文不区分大小写)如表4所示。
, - * /
星期几(Day of week)
可选
0-6或者Sun-Sat(0表示星期天,英文不区分大小写),如表5所示。
, - * ? /
表4 月份字段取值说明 月份
数字
英文简写
1月
1
Jan
2月
2
Feb
3月
3
Mar
4月
4
Apr
5月
5
May
6月
6
Jun
7月
7
Jul
8月
8
Aug
9月
9
Sep
10月
10
Oct
11月
11
Nov
12月
12
Dec
Cron表达式字段特殊字符说明如表6所示。
表6 特殊字符说明 特殊字符
含义
说明
*
表示该字段中的所有值
在“分钟”字段中表示每一分钟都执行。
,
指定多个值(可以不连续)
在“月”字段中指定“Jan,Apr,Jul,Oct”或者“1,4,7,10”,表示1月,4月,7月和10月,在“星期几”字段中指定“Sat,Sun”或者“6,0”表示周六,周日。
-
指定一个范围
在“分钟”字段中使用0-3,表示从0分到3分。
?
指定一个或另一个
仅“日”和“星期几”字段可以指定。例如,如果指定了一个特定的日期,但你不关心该日期对应星期几,那么“星期几”字段就可以使用该特殊字符。
/
表示起步和步幅,n/m表示从n开始,每次增加m
在“分钟”字段1/3表示在满足其它字段情况下,从时间1分(例如00:01:00)开始,每隔3分钟触发一次。
Cron表达式配置示例如表7所示。
表7 Cron表达式配置示例 配置实例
Cron 表达式(以北京时区为例)
每天12点调度函数
CRON_TZ=Asia/Shanghai 0 0 12 * * *
每天12:30调度函数
CRON_TZ=Asia/Shanghai 0 30 12 * * *
每小时的26分,29分,33分调度函数
CRON_TZ=Asia/Shanghai 0 26,29,33 * * * *
周一到周五的每天12:30调度函数
CRON_TZ=Asia/Shanghai 0 30 12 ? * MON-FRI
周一到周五的每天12:00~14:59每5分钟调度函数
CRON_TZ=Asia/Shanghai 0 0/5 12-14 ? * MON-FRI
一月到四月每天12:00调度函数
CRON_TZ=Asia/Shanghai 0 0 12 ? JAN,FEB,MAR,APR *
Cron表达式未设置时,默认以region所在时区运行。如果您的任务需要按照特定时区运行,可以通过CRON_TZ指定,例如在北京时间每个月一号的04:00触发函数执行,则可以使用CRON_TZ=Asia/Shanghai 0 0 4 1 * *。不同地域的时区表达式存在差异,请以实际情况为准。