当前位置:网站首页>解密函数计算异步任务能力之「任务的状态及生命周期管理」
解密函数计算异步任务能力之「任务的状态及生命周期管理」
2022-07-06 18:34:00 【InfoQ】
前言
任务的状态及生命周期的管理
任务的状态管理
- 用户触发一次任务后,任务入队,变更为 Enqueued 状态,并返回触发成功;
- 任务在函数计算后端服务中出队,任务变为 Dequeued 状态;
- 后端会检查任务配置。如果
- 配置了异步消息有效期功能,并且该消息出队时间与入队时间之差已超过有效期,则任务被丢弃,变更为 Expired 状态。任务终止;
- 任务对应的函数已被删除,或创建实例出现错误,则丢弃消息,任务变更为 Invalid 状态;
- 检查后任务正式进入 Running 状态。此时任务已触发实际的执行;
- 任务执行完成后,根据返回会变更为以下几个状态:
- Retrying:用户配置了重试次数(默认为 3),且任务执行失败,这时会进入重试中状态,之后会变更为 Running 状态;
- Failed:任务执行失败,且超过了重试次数。此时会将任务状态改为 Failed;
- Succeeded:任务执行成功。
- 如果在整个状态流转过程用户触发 Cancel,则任务会先变更为 Stopping 状态,并尝试停止任务执行。当任务停止执行成功后,任务进入 Stopped 状态。
任务运行时管理及生命周期
- 创建完成 -> 执行请求阶段:支持 Initializer 功能,支持初始化实例操作。用户可以配置诸如全局变量、连接池初始化等相关操作;
- 执行中 -> 执行完成后 Pause 实例:支持 PreFreeze 接口,支持在函数 Pause 实例前执行用户侧的自定义逻辑;
- 执行中 -> 外部 cancel:函数计算会强制 Restart 用户实例,在 Restart 前支持 PreStop 接口。用户可以配置优雅停止的相关逻辑,以便支持 Cancel 时的自定义行为;
- 完成后 Pause -> 销毁实例:当一段时间没有请求后,函数计算将销毁实例。此时会调用 PreStop 接口,用户可以配置销毁容器的行为(如关闭连接池等)。
任务的停止操作
import fc "github.com/aliyun/fc-go-sdk"
func CancelJob() {
stopInput := fc.NewStopStatefulAsyncInvocationInput("ServiceName", "FunctionName", "TaskUUID")
output, err := fcClient.StopStatefulAsyncInvocation(stopInput)
...
}
总结
边栏推荐
- Redis tool class redisutil (tool class III)
- JS ES5也可以創建常量?
- C language [23] classic interview questions [Part 2]
- centos8安裝mysql報錯:The GPG keys listed for the “MySQL 8.0 Community Server“ repository are already ins
- How can I code for 8 hours without getting tired.
- 一文带你走进【内存泄漏】
- The foreground downloads network pictures without background processing
- Batch delete data in SQL - set in entity
- Blue Bridge Cup 2022 13th provincial competition real topic - block painting
- AcWing 1141. LAN problem solving (kruskalkruskal finding the minimum spanning tree)
猜你喜欢
随机推荐
Flir Blackfly S USB3 工业相机:计数器和定时器的使用方法
新工作感悟~辞旧迎新~
Redis tool class redisutil (tool class III)
Recognition of C language array
JS Es5 can also create constants?
AcWing 1148. Secret milk transportation problem solution (minimum spanning tree)
FLIR blackfly s usb3 industrial camera: white balance setting method
ROS学习(26)动态参数配置
Blackfly S USB3工业相机:缓冲区处理
永久的摇篮
Right mouse button customization
组合导航:中海达iNAV2产品描述及接口描述
JVM 内存模型
HDU 4661 message passing (wood DP & amp; Combinatorics)
Modify the system time of Px4 flight control
@Before, @after, @around, @afterreturning execution sequence
Drag to change order
Centros 8 installation MySQL Error: The gpg Keys listed for the "MySQL 8.0 Community Server" repository are already ins
一片叶子两三万?植物消费爆火背后的“阳谋”
Time synchronization of livox lidar hardware -- PPS method