Celery 是 Distributed Task Queue,分布式任务队列列,分布式决定了了可以有多个 worker 的存在,队列列表示其是异步操作,即存在一个产生任务提出需求的⼯工头,和一群等着被分配工作的 码农。
在 Python 中定义 Celery 的时候,我们要引入 Broker,中⽂文翻译过来就是“中间人”的意思,在这里里 Broker 起到一个中间⼈人的⻆角色。在工头提出任务的时候,把所有的任务放到 Broker 里面,在 Broker 的另外一头,一群码农等着取出一个个任务准备着⼿手做。
什么是backend?
1 | 通常程序发送的消息,发完就完了,可能都不不知道对方时候接受了。为此,celery实现了一个 |
任务模块 Task
1 | 包含异步任务和定时任务。其中,异步任务通常在业务逻辑中被触发并发往任务队列列,而定时任务由 Celery Beat 进程周期性地将任务发往任务队列列。 |
任务执行单元Worker
1 | Worker 是执行任务的处理单元,它实时监控消息队列列,获取队列列中调度的任务,并执行它。 |
任务结果存储 Backend
1 | Backend 用于存储任务的执行结果,以供查询。同消息中间件一样,存储也可使用RabbitMQ, redis 和 MongoDB 等。 |
RabbitMQ是MQ的一种
安装RabbitMQ
1 | sudo apt-get install rabbitmq-server |
设置RabbitMQ
1 | sudo rabbitmqctl add_user carmack 123456 sudo rabbitmqctl add_vhost myvhost |
安装celery
1 | pip install celery -i https://pypi.douban.com/simple |
执行任务
1 | >>> from tasks import add |