Chancy项目中的任务(Jobs)机制详解
2025-06-05 13:45:22作者:秋阔奎Evelyn
什么是Chancy任务
在Chancy项目中,任务(Jobs)是整个系统的核心组件。任务本质上是被工作线程(workers)执行的函数,它们构成了异步任务处理的基础单元。理解并掌握任务的创建和使用方法,是高效利用Chancy框架的关键。
创建任务
基础任务创建
使用@job装饰器可以轻松地将普通函数转换为Chancy任务:
from chancy import job
@job()
def greet():
print("Hello world!")
这个被装饰的函数仍然可以像普通函数一样调用:
greet() # 输出: Hello world!
配置任务参数
在创建任务时,可以指定多种参数来定制任务行为:
@job(
queue="default", # 指定任务队列
priority=1, # 设置优先级
max_attempts=3, # 最大重试次数
kwargs={"name": "World"} # 默认参数
)
def greet(*, name: str):
print(f"Hello, {name}!")
任务队列操作
提交任务到队列
创建任务后,需要将其推送到队列中才会被执行:
async with Chancy("postgresql://localhost/postgres") as chancy:
await chancy.push(greet)
批量提交任务
Chancy支持一次性提交多个任务:
await chancy.push_many([job1, job2, job3])
任务状态追踪
提交任务后会返回一个引用对象,可用于追踪任务状态:
reference = await chancy.push(greet)
finished_job = await chancy.wait_for_job(reference)
print(finished_job.state) # 查看任务最终状态
高级任务配置
任务优先级
通过设置优先级可以控制任务的执行顺序,数值越大优先级越高:
high_priority = greet.job.with_priority(10) # 高优先级
low_priority = greet.job.with_priority(-10) # 低优先级
任务重试机制
配置任务失败时的重试次数:
retry_job = greet.job.with_max_attempts(3) # 最多重试3次
定时任务
可以安排任务在未来特定时间执行:
from datetime import datetime, timedelta, timezone
future_time = datetime.now(timezone.utc) + timedelta(hours=1)
scheduled_job = greet.job.with_scheduled_at(future_time)
注意:定时任务保证在指定时间或之后执行,但不保证精确时间。
资源限制
为任务设置执行时的资源限制:
from chancy import Limit, job
@job(limits=[
Limit(Limit.Type.MEMORY, 1024 * 1024 * 1024), # 1GB内存限制
Limit(Limit.Type.TIME, 60), # 60秒时间限制
])
def resource_intensive_task():
# 执行资源密集型操作
pass
注意:不同执行器支持的限制类型可能不同。
唯一性任务
确保同一时间只有一个特定任务在执行:
unique_job = greet.job.with_unique_key("greet_alice")
await chancy.push(unique_job)
唯一性键保证同一时间只有一个具有相同键的任务处于排队或运行状态。
最佳实践
- 合理设置优先级:关键任务应设置较高优先级,确保及时执行
- 配置适当的重试次数:根据任务重要性设置合理的重试次数
- 使用资源限制:防止单个任务消耗过多系统资源
- 利用唯一性键:避免重复执行相同操作
- 定时任务规划:合理安排非紧急任务的执行时间
通过掌握这些任务配置选项,您可以构建出高效、可靠的异步任务处理系统。
登录后查看全文
热门项目推荐
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0191
cann-learning-hubCANN 学习中心仓,支持在线互动运行、边学边练,提供教程、示例与优化方案,一站式助力昇腾开发者快速上手。Jupyter Notebook0120
Step-3.7-FlashStep-3.7-Flash是一个拥有 1980 亿参数的稀疏混合专家(MoE)视觉语言模型,由 1960 亿参数的语言主干网络和 18 亿参数的视觉编码器组合而成,具备原生图像理解能力。Python00
JoyAI-EchoJoyAI-Echo,这是一个独立的、仅用于推理的版本,旨在实现分钟级多镜头音视频生成。它采用了经过蒸馏的DMD生成器、配对的跨模态记忆以及故事级别的一致性。其性能的核心在于,一个跨模态视听记忆库能够在长达五分钟的视频中保持角色外观和语音音色的一致性。同时,一个训练后处理流程将基于记忆的强化学习与分布匹配蒸馏相结合,实现了7.5倍的速度提升,显著增强了视觉质量和对齐效果。00
fun-rec推荐系统入门教程,在线阅读地址:https://datawhalechina.github.io/fun-rec/Python03
so-large-lm大模型基础: 一文了解大模型基础知识01
热门内容推荐
最新内容推荐
项目优选
收起
暂无描述
Dockerfile
764
4.98 K
本项目是CANN提供的transformer类大模型算子库,实现网络在NPU上加速计算。
C++
857
1.93 K
本项目是CANN提供的神经网络类计算算子库,实现网络在NPU上加速计算。
C++
684
1.33 K
Ascend Extension for PyTorch
Python
720
883
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
1.08 K
1.1 K
deepin linux kernel
C
32
16
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
457
440
用户可使用该项目在 OpenHarmony 平台开发应用,支持通过 IDE 或终端用 Flutter Tools 指令编译构建,基于 Flutter 3.27.4 版本,新增 impeller-vulkan 渲染模式,兼容多种开发指令与环境配置。
Dart
1.01 K
262
华为昇腾面向大规模分布式训练的多模态大模型套件,支撑多模态生成、多模态理解。
Python
151
253
CANNBot 是面向 CANN 开发的用于提升开发效率的系列智能体,本仓库为其提供可复用的 Skills 模块。
Python
1 K
610