博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
python任务调度模块celery
阅读量:5808 次
发布时间:2019-06-18

本文共 1247 字,大约阅读时间需要 4 分钟。

hot3.png

python任务调度模块celery

celery简介

Celery是一个python开发的异步分布式任务调度模块。

Celery本身并不提供消息服务,使用第三方服务,也就是borker来传递任务,一般使用rabbitMQ或者Redis。

  • Celery特点
    简单:一单熟悉了celery的工作流程后,配置和使用还是比较简单的。
    高可用:当任务执行失败或执行过程中发生连接中断,celery 会自动尝试重新执行任务。
    快速:一个单进程的celery每分钟可处理上百万个任务。
    灵活: 几乎celery的各个组件都可以被扩展及自定制。
  • Celery工作流程图
    python-Celery

    celery安装使用

    安装Celery模块
    1
    pip install celery

Celery的默认broker是RabbitMQ,仅需配置一行

1
broker_url = 'amqp://guest:guest@localhost:5672//'

 

RabbitMQ的安装点击查看。

redis作为broker也可以。

  • 安装

    1
    pip install redis
  • 配置

    broker_url配置redis数据库地址,格式为redis://:password@hostname:port/db_number
    backend配置任务结果存储位置,将保存每个任务的执行结果。

    12
    app.conf.broker_url = 'redis://localhost:6379/0'app.conf.result_backend = 'redis://localhost:6379/0'

port和db_number是可选项,默认情况下端口使用6379,db_number使用0。

  • 示例
    创建一个celery application定义任务列表,新建一个celery1.py文件
    12345678
    from celery import Celerybroker = "redis://118.24.18.158:6379/5"backend = "redis://118.24.18.158:6379/6"app = Celery("celery1", broker=broker, backend=backend)@app.taskdef add(x, y):    return x+y

启动Celery Worker开始监听并执行任务

1
celery -A celery1 worker --loglevel=info

 

调用任务

123456789
import timefrom celery1 import addre = add.delay(10, 20)print(re)print(re.status)time.sleep(8)print(re.status)print(re.result)

转载于:https://my.oschina.net/u/3803404/blog/1819727

你可能感兴趣的文章
让你的APP实现即时聊天功能
查看>>
iOS 绝对路径和相对路径
查看>>
使用Openfiler搭建ISCSI网络存储
查看>>
应用新安全组 - 每天5分钟玩转 OpenStack(116)
查看>>
4.3. 键盘设置
查看>>
iOS - UIViewController
查看>>
IntPtr 转 string
查看>>
一文搞懂各种 Docker 网络 - 每天5分钟玩转 Docker 容器技术(72)
查看>>
学生名单
查看>>
(转) 多模态机器翻译
查看>>
【官方文档】Nginx负载均衡学习笔记(三) TCP和UDP负载平衡官方参考文档
查看>>
矩阵常用归一化
查看>>
Oracle常用函数总结
查看>>
【聚能聊有奖话题】Boring隧道掘进机完成首段挖掘,离未来交通还有多远?
查看>>
CMake 手册详解(二十)
查看>>
嵌入式 busybox自带的tftp、telnet、ftp服务器
查看>>
USNews大学排名遭美国计算机研究学会怒怼,指排名荒谬要求撤回
查看>>
struts1——静态ActionForm与动态ActionForm
查看>>
七大关键数据 移动安全迎来历史转折点
查看>>
在AngularJS中学习javascript的new function意义及this作用域的生成过程
查看>>