异步任务主要用于支持长任务、重计算场景。函数服务提供 Webserver 模式 和 非 Webserver 模式 的异步任务。两者的主要区别在于业务侧是否需要基于一个 WebServer 来处理请求,在业务场景上并无明显差异。本文为您介绍如何开启这两种模式的异步任务。
前提条件
已在本地完成代码开发,具体请参见 Native 函数开发指南。其中,开发方法章节,Webserver 模式请参照应用托管章节,非 Webserver 模式请参照任务托管章节。
使用限制
- 不支持切换同步/异步模式。仅支持创建函数时选择是否开启异步任务模式,函数创建后该配置将锁定,不提供修改更新操作。
- 不支持切换异步任务的 Webserver 模式/非 Webserver 模式。
- 不支持单实例多并发,每个函数实例只能同时处理一个异步任务。如果您的任务 QPS 较高,建议提高当前函数的 实例数上限 配置。
- 仅支持对系统错误进行自动重试,暂不支持用户侧的任务重试。
- 当前支持的任务执行时长范围为 10 s ~ 3 h。
- 任务执行状态最长可保存 24 h。
- 当前支持的事件触发类型有:API 网关触发器、Timer 触发器。
- 异步任务 Payload 最大支持 128 KB。
- 事件调用成功,返回信息只包含 RequestId。事件执行结果需要在函数代码逻辑中自行实现回调特定的 API 或者发送通知消息。
操作步骤
- 创建异步任务函数。
说明
推荐启用日志功能,否则无法查询历史任务的执行日志。
- 将函数 发布 至线上。
后续操作
提交任务,通过异步模式调用函数。提交任务、终止任务等详情可参见 任务管理。