当前位置:网站首页>解密函数计算异步任务能力之「任务的状态及生命周期管理」
解密函数计算异步任务能力之「任务的状态及生命周期管理」
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)
...
}
总结
边栏推荐
- Threadlocalutils (tool class IV)
- Livox激光雷达硬件时间同步---PPS方法
- 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
- 开发中对集合里面的数据根据属性进行合并数量时犯的错误
- 制作带照明的DIY焊接排烟器
- sql中批量删除数据---实体中的集合
- ROS learning (XIX) robot slam function package cartographer
- 字符串的相关编程题
- Redis tool class redisutil (tool class III)
猜你喜欢
处理streamlit库上传的图片文件
2022/0524/bookstrap
ROS学习(二十)机器人SLAM功能包——rgbdslam的安装与测试
sql中批量删除数据---实体中的集合
3D激光SLAM:Livox激光雷达硬件时间同步
JS how to quickly create an array with length n
ROS学习(21)机器人SLAM功能包——orbslam的安装与测试
STM32F4---通用定时器更新中断
Flir Blackfly S 工业相机:通过外部触发实现多摄像头同步拍摄
Analyze "C language" [advanced] paid knowledge [i]
随机推荐
@Before, @after, @around, @afterreturning execution sequence
ROS learning (23) action communication mechanism
Time synchronization of livox lidar hardware -- PPS method
MySQL execution process and sequence
Public key \ private SSH avoid password login
Telnet,SSH1,SSH2,Telnet/SSL,Rlogin,Serial,TAPI,RAW
FLIR blackfly s industrial camera: synchronous shooting of multiple cameras through external trigger
最近小程序开发记录
刨析《C语言》【进阶】付费知识【完结】
ROS学习(十九)机器人SLAM功能包——cartographer
Flir Blackfly S USB3 工业相机:计数器和定时器的使用方法
Blackfly S USB3工业相机:缓冲区处理
FLIR blackfly s industrial camera: auto exposure configuration and code
ROS学习(23)action通信机制
Introduction to microservice architecture
传感器:DS1302时钟芯片及驱动代码
将截断字符串或二进制数据
C language [23] classic interview questions [Part 2]
POJ 3177 redundant paths POJ 3352 road construction (dual connection)
XML to map tool class xmlmaputils (tool class V)