Django-celery

选择中间人
Celery 需要一个发送和接收消息的解决方案,其通常以独立服务形式出现, 称为 消息中间人

RabbitMQ

sudo apt-get install rabbitmq-server

命令执行完成后,中间人就已经运行在后台,准备好传输消息: Starting rabbitmq-server: SUCCESS

Redis

使用 Redis

一般不推荐将数据存在数据库,对于很小的项目可能是适合的

也可以使用 Amazon SQSUsing MongoDBIronMQ ,但是官方推荐使用Redis和RabbitMQ.

未命名.jpg

安装celery

 pip install celery

应用

在项目app目录下,创建 tasks.py

from celery import Celery
app = Celery('tasks', broker='amqp://guest@localhost//')
@app.taskdef add(x, y): 
      return x + y
AsyncResult实例:
result = add.delay(4,4)
result.ready()   #查看任务是否完成处理
result.get(timeout=1)   #等待任务完成,返回结果,但这就将异步变成同步
result.get(propagate=False) #倘若任务抛出了一个异常,get()会重新抛出异常, 但你可以指定 propagate
 参数来覆盖这一行为
result.traceback #如果任务抛出了一个异常,你也可以获取原始的回溯信息

配置

config.py

## Broker设置。
BROKER_URL = 'redis://localhost:6379/0'
CELERY_RESULT_BACKEND = 'redis://localhost:6379/0'  #Redis 结果后端
'''

CELERY_RESULT_BACKEND='redis://:password@host:port/db'
host: Redis的服务器的名称或IP地址。例如 localhost:本地主机。
port: Redis的服务器。默认值是6379
db: 使用的数据库数,默认值为0
password: 密码用于连接到数据库。

缓存后端设置
使用单个memcached服务器:
CELERY_RESULT_BACKEND='cache+memcached://127.0.0.1:11211/'
cache : 缓存
'''

or
BROKER_URL = 'amqp://'
CELERY_RESULT_BACKEND = 'amqp://'
CELERY_TASK_RESULT_EXPIRES = 18000 # 5 hours.
'''
同时,AMQP后端需要的RabbitMQ 1.1.0或更高版本以自动失效的结果。如果你正在运行的RabbitMQ的是旧版本,你应该禁用这样的结果是到期:
CELERY_TASK_RESULT_EXPIRES =无

'''

CELERY_CACHE_BACKEND = ‘memory’  #只在内存中缓存
BROKER_TRANSPORT_OPTIONS = {'visibility_timeout': 3600} # 1 hour. Redis 的默认可见性超时时间是 1 小时。
#列出导入模块
CELERY_IMPORTS=('myapp.tasks',)
app.conf.CELERY_TASK_SERIALIZER = 'json'
#一次性添加多个配置
app.conf.update( 
      CELERY_TASK_SERIALIZER='json', 
      CELERY_ACCEPT_CONTENT=['json'], # Ignore other content 
      CELERY_RESULT_SERIALIZER='json',
      CELERY_TIMEZONE='Europe/Oslo', 
      CELERY_ENABLE_UTC=True,
)
#处理繁重任务的专用队列
CELERY_ROUTES = { 
      'tasks.add': 'low-priority',
}
#限制任务的速率,这样每分钟只允许处理 10 个该类型的任务
CELERY_ANNOTATIONS = { 
        'tasks.add': {'rate_limit': '10/m'}
}
CELERY_ANNOTATIONS={'*':{'rate_limit':'10/s'}}   #限制所有任务处理
如果你使用 RabbitMQ 或 Redis 作为中间人,那么你也可以在运行时直接在职程上设置速率限制:
$ celery control rate_limit tasks.add 10/mworker@example.com: OK new rate limit set successfully

[并发设置]
CELERYD_CONCURRENCY   #默认是你的cpu可用数量

你可以调用 config_from_object()
来让 Celery 实例加载配置模块:

app.config_from_object('celeryconfig')

验证配置模块:

python -m celeryconfig

配置选项的完整参考见 Configuration and defaults

注意

1.确保任务没有启用 ignore_result 。启用这个选项会强制所有职程跳过状态更行。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,657评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,662评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,143评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,732评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,837评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,036评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,126评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,868评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,315评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,641评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,773评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,859评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,584评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,676评论 2 351

推荐阅读更多精彩内容