前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >celer守护进程 celery 后台运行beat worker 定时任务

celer守护进程 celery 后台运行beat worker 定时任务

作者头像
用户8644430
发布2022-03-30 17:40:30
6560
发布2022-03-30 17:40:30
举报
文章被收录于专栏:celerycelery

#0 GitHub

代码语言:javascript
复制
https://github.com/Coxhuang/celery

#1 环境

代码语言:javascript
复制
centos 6.9 
django==2.0.7
celery==3.1.23
django-celery==3.2.2

#2 celery使用(定时任务)

???celery4 定时任务配置使用(传送门) ???celery4 异步任务配置使用(传送门)

#3 后台启动worker / beat

#3.1 后台运行Worker

代码语言:javascript
复制
cd 项目根目录
celery multi start w1 -A  celery_pro -l info  # 开始
celery multi stop w1 -A  celery_pro -l info # 结束

设置成脚本文件

代码语言:javascript
复制
vim /opt/celery_worker.sh
代码语言:javascript
复制
#!/bin/sh 
case $1 in                                        
   start) cd /opt/django-celery/ && celery multi start w1 -A  celery_pro -l info;;  # django项目根目录 : /opt/django-celery/
   stop) cd /opt/django-celery/ && celery multi stop w1 -A  celery_pro -l info;; # django项目根目录 : /opt/django-celery/
   *) echo "require start|stop" ;;     
esac

使用

代码语言:javascript
复制
sh celery_worker.sh start # 开启
sh celery_worker.sh stop # 关闭

#3.3 后台运行 beat

没有找到官方提供的beat后台运行命令,所以,自己写

  • 后台启动beat

新增脚本 vim /opt/celery_beat.sh

代码语言:javascript
复制
vim /opt/celery_beat.sh
代码语言:javascript
复制
#!/bin/sh
case $1 in  
   start) cd /opt/django-celery/ && celery -A celery_pro beat -l info >  out.file  2>&1  & ;; # 启动beat ; django项目根目录 : /opt/django-celery/
esac 
  • 关闭beat

新增脚本 vim /opt/beat_stop.sh

代码语言:javascript
复制
vim /opt/beat_stop.sh
代码语言:javascript
复制
#!/bin/sh               
PROCESS=`ps -ef|grep celery|grep -v grep|grep -v PPID|awk '{ print $2}'`
for i in $PROCESS         
do
  echo "Kill the $1 process [ $i ]"  
  kill -9 $i        
done 

编辑脚本 vim /opt/celery_beat.sh

代码语言:javascript
复制
vim /opt/celery_beat.sh
代码语言:javascript
复制
#!/bin/sh
case $1 in  
   start) cd /opt/django-celery/ && celery -A celery_pro beat -l info >  out.file  2>&1  & ;; # 启动beat  ; django项目根目录 : /opt/django-celery/
   stop) su root /opt/beat_stop.sh start ;; # 关闭beat(根据beat_stop.sh脚本的路径适当变化)
   *) echo "require start|stop" ;;
esac 

#6.3 使用小结

  • 后台启动worker, sh celery_worker.sh start
  • 后台关闭worker, sh celery_worker.sh stop
  • 后台启动beat, sh celery_beat.sh start
  • 后台关闭beat, sh celery_beat.sh stop

本文系转载,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文系转载前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • #0 GitHub
  • #1 环境
  • #2 celery使用(定时任务)
  • #3 后台启动worker / beat
    • #3.1 后台运行Worker
      • #3.3 后台运行 beat
        • #6.3 使用小结
    领券
    问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档