20 python--celery

Celery概述

关于celery的定义,首先来看官方网站:Celery(芹菜) 是一个简单、灵活且可靠的,处理大量消息的分布式系统,而且提供维护这样一个系统的必需工具。html

简单来看,是一个基于python开发的分布式异步消息任务队列,持使用任务队列的方式在分布的机器、进程、线程上执行任务调度。经过它能够轻松的实现任务的异步处理, 若是你的业务场景中须要用到异步任务,就能够考虑使用celery, 举几个实例场景中可用的例子:python

  1. 你想对100台机器执行一条批量命令,可能会花很长时间 ,但你不想让你的程序等着结果返回,而是给你返回 一个任务ID,你过一段时间只须要拿着这个任务id就能够拿到任务执行结果, 在任务执行ing进行时,你能够继续作其它的事情。   
  2. 你想作一个定时任务,好比天天检测一下大家全部客户的资料,若是发现今天 是客户的生日,就给他发个短信祝福 。  

Celery 在执行任务时须要经过一个中间人(消息中间件)来接收和发送任务消息,以及存储任务结果,完整的中间人列表请查阅官方网站redis

PS:任务队列是一种在线程或机器间分发任务的机制。架构

PS:消息队列的输入是工做的一个单元,称为任务,独立的工做(Worker)进程持续监视队列中是否有须要处理的新任务。 并发

Celery简介

Celery 系统可包含多个职程和中间人,以此得到高可用性和横向扩展能力,其基本架构由三部分组成,消息中间件(message broker),任务执行单元(worker)和任务执行结果存储(task result store)组成。app

  1. 消息中间件,Celery自己不提供消息服务,可是能够方便的和第三方提供的消息中间件集成,通常使用rabbitMQ or Redis,固然其余的还有MySQL以及Mongodb。
  2. 任务执行单元,Worker是Celery提供的任务执行的单元,worker并发的运行在分布式的系统节点中。
  3. 任务结果存储,Task result store用来存储Worker执行的任务的结果,Celery支持以不一样方式存储任务的结果,包括Redis,MongoDB,Django ORM,AMQP等。

Celery的主要特色:异步

  1. 简单:一单熟悉了celery的工做流程后,配置和使用仍是比较简单的
  2. 高可用:当任务执行失败或执行过程当中发生链接中断,celery 会自动尝试从新执行任务
  3. 快速:一个单进程的celery每分钟可处理上百万个任务
  4. 灵活: 几乎celery的各个组件均可以被扩展及自定制

Celery基本工做流程图

一、用户应用程序讲任务经过celery放入Broker中。分布式

  二、多个worker经过Broker获取任务并执行。工具

  三、worker执行完成后,会把任务的结果、状态等信息返回到Broker中存储,供用户程序读取。网站

PS:Celery 用消息通讯,一般使用中间人(Broker)在客户端和职程间斡旋。这个过程从客户端向队列添加消息开始,以后中间人把消息派送给职程。

Celery模块的基本使用

# 利用pip3命令安装celery模块

pip3 install celery
 
用来定义任务列表,这里任务文件的名称叫作task.py(注意后面会用到文件名)。
from celery import Celery
 
app = Celery('task',  # 是当前模块的名称,这个参数是必须的,这样的话名称能够自动生成
    broker="redis://192.168.100.83:6379/0",     # 中间人的地址
    backend="redis://192.168.100.83:6379/1"   # 结果数据存放地址
)
 
@app.task     # 使用celery标识一个任务,多个任务都须要使用该装饰器 
def add(x,y):    
    return x+y

其余中间件

1 # rabbitmq
2 broker = 'amqp://user:password@ip:5672//'
3 
4 # redis
5 broker = 'redis://passwordf@ip:6379/db'

运行一个worker

elery -A task worker --loglevel=debug
 
# -A参数表示的是Celery APP的名称,task就是APP的名称(应用文件名)
# worker表示是一个执行任务角色
# loglevel=info记录日志类型默认是info

生产者

form ling import add
re = add.delay(10, 20)
print(re.result)    #获取结果
print(re.ready)        #是否处理
print(re.get(timeout=1))        #获取结果
print(re.status)        #是否处理
相关文章
相关标签/搜索