设为首页 收藏本站
查看: 1064|回复: 0

[经验分享] python—Celery异步分布式

[复制链接]

尚未签到

发表于 2018-8-4 13:07:47 | 显示全部楼层 |阅读模式
  一、Celery异步分布式
  
  Celery  是一个python开发的异步分布式任务调度模块,是一个消息传输的中间件,可以理解为一个邮箱,每当应用程序调用celery的异步任务时,会向broker传递消息,然后celery的worker从中取消息
  Celery  用于存储消息以及celery执行的一些消息和结果
  对于brokers,官方推荐是rabbitmq和redis
  对于backend,也就是指数据库,为了简单一般使用redis
   DSC0000.jpg
  使用redis连接url格式:
  redis://:password@hostname:port/db_number
  
  1)定义连接脚本tasks.py
#!/usr/bin/env python  
from celery import Celery
  
broker = "redis://192.168.2.230:6379/1"
  
backend = "redis://192.168.2.230:6379/2"
  
app = Celery("tasks", broker=broker, backend=backend)
  

  
@app.task
  
def add(x,y):
  
    return x+y
  2)安装启动celery
  pip install celery
  pip install redis
  启动方式:celery -A huang tasks -l info  #-l 等同于 --loglevel
DSC0001.jpg

  3)执行测试 huang.py
#!/usr/bin/env python  
from tasks import add
  

  
re = add.delay(10,20)
  

  
print(re.result)   #任务返回值
  
print(re.ready)     #如果任务被执行返回True,其他情况返回False
  

  
print(re.get(timeout=1))  #带参数的等待,最后返回结果
  
print(re.status)  #任务当前状态
  运行结果:
  30
  <bound method AsyncResult.ready of <AsyncResult: d2e0a2d8-cdd9-4fe3-a8bb-81fe3c53ba9a>>
  30
  SUCCESS
  4)根据成功返回的key或celery界面输出的信息,查看redis存储
DSC0002.jpg

  说明:停止celery服务,执行完huang.py之后,再启动celery服务也是有保存数据的
  
  二、celery多进程
   DSC0003.jpg
  1)配置文件 celeryconfig.py
#!/usr/bin/env python  
#-*- coding:utf-8 -*-
  

  
from kombu import Exchange,Queue
  

  
BROKER_URL = &quot;redis://192.168.2.230:6379/3&quot;
  
CELERY_RESULT_BACKEND = &quot;redis://192.168.2.230:6379/4&quot;
  

  
CELERY_QUEUES = (
  
Queue(&quot;default&quot;,Exchange(&quot;default&quot;),routing_key=&quot;default&quot;),
  
Queue(&quot;for_task_A&quot;,Exchange(&quot;for_task_A&quot;),routing_key=&quot;for_task_A&quot;),
  
Queue(&quot;for_task_B&quot;,Exchange(&quot;for_task_B&quot;),routing_key=&quot;for_task_B&quot;)
  
)
  

  
CELERY_ROUTES = {
  
'tasks.taskA':{&quot;queue&quot;:&quot;for_task_A&quot;,&quot;routing_key&quot;:&quot;for_task_A&quot;},
  
'tasks.taskB':{&quot;queue&quot;:&quot;for_task_B&quot;,&quot;routing_key&quot;:&quot;for_task_B&quot;}
  
}
  2)tasks.py
#!/usr/bin/env python  
#-*- coding:utf-8 -*-
  

  
from celery import Celery
  

  
app = Celery()
  
app.config_from_object(&quot;celeryconfig&quot;)
  

  
@app.task
  
    def taskA(x,y):
  
    return x+y
  

  
@app.task
  
    def taskB(x,y,z):
  
    return x+y+z
  3)启动celery
  celery -A tasks worker --loglevel info
  4)执行脚本huang2.py
#!/usr/bin/env python  
#-*- coding:utf-8 -*-
  

  
from tasks import taskA,taskB
  

  
re = taskA.delay(10,20)
  

  
print(re.result)   #任务返回值
  
print(re.ready)     #如果任务被执行返回True,其他情况返回False
  
print(re.get(timeout=1))  #带参数的等待,最后返回结果
  
print(re.status)  #任务当前状态
  

  
re2 = taskB.delay(10,20,30)
  
print(re2.result)
  
print(re2.ready)
  
print(re2.get(timeout=1))
  
print(re2.status)
  
  5)运行结果
  None
  <bound method AsyncResult.ready of <AsyncResult: e34a8490-05a7-473e-a082-f4956cabfc99>>
  30
  SUCCESS
  None
  <bound method AsyncResult.ready of <AsyncResult: 3c5cd839-dbe2-4e63-ba4e-86e8c79d943f>>
  60
  SUCCESS

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-546506-1-1.html 上篇帖子: python备份脚本解析 下篇帖子: CentOS6.5安装python2.7.9-12470612
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表