celery 的使用

知乎文章:
Celery 快速入门
某博客:
Celery 快速入门
周期任务
celery 分布式广播通知
class based celery tasks
celery 官方总结的常见问题
celery有什么难理解的
记一次 celery 中的内存泄露问题
自己的要求:必须精通celery 因为自已要用到( tm 在其他应用里面 的 tasks 文件里面 @share_task 还是没试成功, 老是报错, 文章后面会提一下)

其实用 @app.task 吧,能解决大部分任务了,share_task 的在找一下原因
简介:
Celery是一个简单,灵活且可靠的分布式系统,可以处理大量消息,同时为操作提供维护该系统所需的工具。

这是一个任务队列,着重于实时处理,同时还支持任务调度

安装redis的celery:

pip install -U "celery[redis]"

创建任务实例:

from celery import Celery

app = Celery('tasks', broker='redis://localhost:6379/0')
# broker 是你redis 的地址,默认使用 0 数据库


@app.task
def send_mail(email):
    print("send mail to ", email)
    import time
    time.sleep(5)
    return "success"
# 函数用app.task 装饰器修饰之后,就会成为Celery中的一个Task。

启动任务:
先启动redis-server:

redis-server.exe
进入redis 安装目录写,或者配置好全局变量后直接写

运行一个任务:

最好是进入模块所在的目录运行  其中tasks 是模块名字
celery -A tasks worker --loglevel=info

要调用我们的任务,您可以使用[delay()]
新启动命令窗口,进到模块目录 :

from 模块 import  任务函数
运行 funcname.delay([args..])
结果如下图
执行提示 窗口1

执行结果 窗口2

调用周期任务,必须先添加完整的定时表:

from celery import Celery
from celery.schedules import crontab

app = Celery()

@app.on_after_configure.connect
def setup_periodic_tasks(sender, **kwargs):
    # Calls test('hello') every 10 seconds.
    sender.add_periodic_task(10.0, test.s('hello'), name='add every 10')

    # Calls test('world') every 30 seconds
    sender.add_periodic_task(30.0, test.s('world'), expires=10)

    # Executes every Monday morning at 7:30 a.m.
    sender.add_periodic_task(
        crontab(hour=7, minute=30, day_of_week=1),
        test.s('Happy Mondays!'),
    )

@app.task
def test(arg):
    print(arg)

或者手动:

app.conf.beat_schedule = {
    'add-every-30-seconds': {
        'task': 'tasks.add',
        'schedule': 30.0,
        'args': (16, 16)
    },
}
app.conf.timezone = 'UTC'

启动周期任务:

celery -A tests beat

启动worker 节点,运行任务:

celery -A tests worker

上面的tests 都是写任务那个模块的名字
结果:


十秒一次的周期任务

目录下 celery 的任务运行
[django 中使用celery]%E5%8A%A1/)

celery api 参考

我们项目大致使用celery 的思路:

pip install django_celery_beat
并且 注册到 app :
django_celery_beat,

settings.py

# CELERY_RESULT_BACKEND = 'django-db'
CELERY_TIMEZONE = 'Asia/Shanghai'
CELERY_ENABLE_UTC = False
DJANGO_CELERY_BEAT_TZ_AWARE = False  # fix bug https://github.com/celery/django-celery-beat/issues/109
CELERY_ACCEPT_CONTENT = ['json']
CELERY_TASK_SERIALIZER = 'json'
CELERYD_MAX_TASKS_PER_CHILD = 10

celery.py:

os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'ops.settings')

app = Celery('ops',
             broker=broker)
app.config_from_object('django.conf:settings',  namespace='CELERY')
# 然后 就是settings 里面那些 配置了
# 最后来一句
# Load task modules from all registered Django app configs.
app.autodiscover_tasks()

使用celery 进行流量统计

启动worker 报错,不能找到其他文件夹模块,原因参考

关于 share_task 和 task 的区别
简单说就是 share_task 不需要绑定到具体的 celery app 实例, >@shared_task将为每个应用程序创建任务的独立实例,从而使任务可重用

这个就是说,你的 任务和 celery 应用是解耦的。大概是这样,
你的任务也可以直接在其他项目中使用。和本身dj 项目没关系?

简书的文章,翻译的官方的celery 使用 django

显示 @share_task 的任务未注册

原来我 celery 里有个 配置顺序写错了,看了官方文档特意强调了这个。我才认识到这个问题

os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'transform_server.settings')

app = Celery('transform_server', broker="redis://:{passwd}@localhost:6379/0".format(passwd=encrypt_passwd))   # 1

app.config_from_object('django.conf:settings',  namespace='CELERY')  # 2

app.autodiscover_tasks()

os.environ.setdefault 这一句写在 app 初始化之前。否则 其他的应用的 tasks 注册不了

看 celery 解释
也许是让 celery 在django 应用都加载完毕,才生成 celery app , 我猜的
成功后的 显示

(ps:改了task 的代码,记得要重启一下,celery 的服务,不然用的还是老代码)

在生产环境 就最好不要使用 celery -A 这种方式了, 因为这个是 开发调试用的.
生产推荐使用 supervisor

安装 : 
1 pip install supervisor
参考: https://www.cnblogs.com/debochan/p/10823984.html

2 echo_supervisord_conf > supervisord.conf

3 supervisord.conf  在最后一行添加内容:

[program:celery]
#Set full path to celery program if using virtualenv
command=celery -A worker transform_server --loglevel=INFO   # -A 在前面 worker 在后面
directory=/usr/src/transform_server
# environment=CELERY_CONFIG_MODULE="celerytask.celeryconfig-dev"

numprocs=1 ;进程数
autostart=true ;当supervisor启动时,程序将会自动启动
autorestart=true ;自动重启

4 启动supervisor:
supervisord -c supervisord.conf

5 关闭supervisord
supervisorctl -c supervisord.conf shutdown

6.重启supervisord
supervisorctl -c supervisord.conf reload

supervisor 日志配置文件 默认在 /tmp/supervisord.log 目录

注意 由于celery 启动 并不是和 服务一起的,他是两个进程的服务,所以不要像,用 celery 改变当前服务的内存方面的东西,比如我想 直接在任务函数里面修改 server 程序的 类属性,就不会生效的, celery 能做的就是 除了进城之外的,还是哪个话题,进城通信, 而且是不同机器的,只能通过数据库,等持久化的中间层了。或者通过 request 请求。
关于 request 请求更改服务进城的属性,已经验证过了,是会影响当前进城的其他地方的是使用

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

推荐阅读更多精彩内容