Kof*_*ohn 5 python daemon celery
我一直在努力将我的celery任务设置为守护进程,以便按计划处理数据.
我一直在关注文档以设置我的守护进程,但是一直在遇到一个日志文件权限错误,这让我很难过.
以下是我在Digital Ocean上的ubuntu盒子上设置的配置
在/ etc /默认/ celeryd
# here we have a single node
CELERYD_NODES="w1"
CELERY_BIN = "/mix_daemon/venv/bin/celery"
CELERYD_CHDIR="/mix_daemon/"
CELERYD_OPTS="-A tasks worker --loglevel=info --beat"
# %n will be replaced with the nodename.
CELERYD_LOG_FILE="/var/log/celery/%n.log"
CELERYD_PID_FILE="/var/run/celery/%n.pid"
CELERY_CREATE_RUNDIR=0
CELERY_CREATE_LOGDIR=0
# Workers should run as an unprivileged user.
CELERYD_USER="celery"
CELERYD_GROUP="celery"
Run Code Online (Sandbox Code Playgroud)
但是,当我跑
sh -x /etc/init.d/celeryd start
Run Code Online (Sandbox Code Playgroud)
我收到以下错误消息:
celery multi v3.1.7 (Cipater)
> Starting nodes...
> celery@mix: OK
Traceback (most recent call last):
File "/usr/lib/python2.7/runpy.py", line 162, in _run_module_as_main
"__main__", fname, loader, pkg_name)
File "/usr/lib/python2.7/runpy.py", line 72, in _run_code
exec code in run_globals
File "/home/john/mix_daemon/venv/lib/python2.7/site-packages/celery/bin/celeryd_detach.py", line 168, in <module> main()
File "/home/john/mix_daemon/venv/lib/python2.7/site-packages/celery/bin/celeryd_detach.py", line 165, in main
detached_celeryd(app).execute_from_commandline()
File "/home/john/mix_daemon/venv/lib/python2.7/site-packages/celery/bin/celeryd_detach.py", line 160, in execute_from_commandline
**vars(options)
File "/home/john/mix_daemon/venv/lib/python2.7/site-packages/celery/bin/celeryd_detach.py", line 42, in detach
with detached(logfile, pidfile, uid, gid, umask, working_directory, fake):
File "/home/john/mix_daemon/venv/local/lib/python2.7/site-packages/celery/platforms.py", line 314, in open
self.after_chdir()
File "/home/john/mix_daemon/venv/local/lib/python2.7/site-packages/celery/platforms.py", line 384, in after_chdir_do
logfile and open(logfile, 'a').close()
IOError: [Errno 13] Permission denied: '/var/log/celery/celery.log'
+ sleep 5
+ exit 0
Run Code Online (Sandbox Code Playgroud)
我看了这个错误信息,从redmine项目中看到了这个答案.所以我尝试了以下尝试允许芹菜工作者写入日志文件:
$ sudo mkdir -p -m 2755 /var/log/celery
$ sudo chown celery:celery /var/log/celery
Run Code Online (Sandbox Code Playgroud)
但是当我尝试启动守护进程时仍然存在相同的错误.
我是一个芹菜菜鸟,对此的任何帮助将不胜感激!
小智 3
根据文档:
初始化脚本只能由root使用,shell配置文件也必须由root拥有”
所以,你需要运行:
sudo chown root:root /etc/default/celeryd
Run Code Online (Sandbox Code Playgroud)
和
sudo /etc/init.d/celeryd start
Run Code Online (Sandbox Code Playgroud)
顺便说一下,你的 celeryd 配置文件中有无效的语法:
CELERY_BIN = "/mix_daemon/venv/bin/celery"
Run Code Online (Sandbox Code Playgroud)
“=”运算符中不允许有空格,正确的是:
CELERY_BIN="/mix_daemon/venv/bin/celery"
Run Code Online (Sandbox Code Playgroud)
另请检查您的垃圾箱是否位于 /mix_daemon 而不是 /home//mix_daemon
| 归档时间: |
|
| 查看次数: |
4451 次 |
| 最近记录: |