【问题标题】:celery daemon using systemd not running使用 systemd 的 celery 守护进程未运行
【发布时间】:2017-05-27 12:26:04
【问题描述】:

我正在使用 ubuntu 16 和 systemd 将 celery 作为守护进程运行。我也创建了单元文件,但我无法将 celery 作为服务运行。为什么会出现这个错误?

/etc/systemd/system/celery.service

[Unit]
Description=Celery Service
After=network.target

[Service]
Type=forking
User=celery
Group=celery
EnvironmentFile=-/etc/default/celery
WorkingDirectory=/srv/weaver/src
ExecStart=/bin/sh -c '${CELERY_BIN} multi start ${CELERYD_NODES} \
  -A ${CELERY_APP} --pidfile=${CELERYD_PID_FILE} \
  --logfile=${CELERYD_LOG_FILE} --loglevel=${CELERYD_LOG_LEVEL} ${CELERYD_OPTS}'
ExecStop=/bin/sh -c '${CELERY_BIN} multi stopwait ${CELERYD_NODES} \
  --pidfile=${CELERYD_PID_FILE}'
ExecReload=/bin/sh -c '${CELERY_BIN} multi restart ${CELERYD_NODES} \
  -A ${CELERY_APP} --pidfile=${CELERYD_PID_FILE} \
  --logfile=${CELERYD_LOG_FILE} --loglevel=${CELERYD_LOG_LEVEL} ${CELERYD_OPTS}'

[Install]
WantedBy=multi-user.target

文件位于 /etc/default/celery

ENABLED="true"
CELERYD_NODES="worker1"
#CELERYD_NODES="worker1 worker2 worker3"
CELERY_BIN="/usr/local/bin/celery"
CELERY_APP="main:celery_app"
CELERYD_CHDIR="/srv/weaver/src"
CELERYD_OPTS=" --queue=weaver  --time-limit=100000 --concurrency=2"
CELERYD_LOG_FILE="/var/log/celery/%N.log"
CELERYD_PID_FILE="/var/run/celery2/%N.pid"
CELERYD_USER="celery"
CELERYD_GROUP="celery"
CELERY_CREATE_DIRS=1
# Change Celery Beat
CELERYBEAT_CHDIR="/srv/weaver/src"
# Log files
CELERYBEAT_LOG_FILE="/var/log/celery/celerybeat.log"
# Celery Beat Log files
CELERYBEAT_PID_FILE="/var/run/celery/celerybeat.pid"
# Scheduler for celery
CELERYBEAT_OPTS=" --pidfile=/var/run/celery/celerybeat.pid  --sch

运行服务的输出

● celery.service - Celery Service
   Loaded: loaded (/etc/systemd/system/celery.service; disabled; vendor preset: enabled)
   Active: failed (Result: exit-code) since Thu 2017-01-12 17:12:32 IST; 2min 17s ago
  Process: 18561 ExecStop=/bin/sh -c ${CELERY_BIN} multi stopwait ${CELERYD_NODES}    --pidfile=${CELERYD_PID_FILE} (code=exited, status=0/SUCCESS)
  Process: 18540 ExecStart=/bin/sh -c ${CELERY_BIN} multi start ${CELERYD_NODES}    -A ${CELERY_APP} --pidfile=${CELERYD_PID_FILE}    --logfile=${CELERYD_LOG_FIL
 Main PID: 18555 (code=exited, status=1/FAILURE)

Jan 12 17:12:30 fb01 systemd[1]: Starting Celery Service...
Jan 12 17:12:31 fb01 sh[18540]: celery multi v3.1.23 (Cipater)
Jan 12 17:12:31 fb01 sh[18540]: > Starting nodes...
Jan 12 17:12:31 fb01 sh[18540]:         > worker1@fb01: OK
Jan 12 17:12:31 fb01 systemd[1]: Started Celery Service.
Jan 12 17:12:32 fb01 systemd[1]: celery.service: Main process exited, code=exited, status=1/FAILURE
Jan 12 17:12:32 fb01 sh[18561]: celery multi v3.1.23 (Cipater)
Jan 12 17:12:32 fb01 sh[18561]: > worker1@fb01: DOWN
Jan 12 17:12:32 fb01 systemd[1]: celery.service: Unit entered failed state.
Jan 12 17:12:32 fb01 systemd[1]: celery.service: Failed with result 'exit-code'.

【问题讨论】:

  • 请同时包含 celery 日志文件的内容,路径在您提供的配置文件中定义:CELERYD_LOG_FILE="/var/log/celery/%N.log"
  • @running.t 日志为空。 ubuntu 系统无法将其作为服务运行,这就是错误的原因
  • 那么我不确定是否有人能够帮助您。您显示的唯一信息是 celery 以退出代码 1 退出。您必须以某种方式对其进行调试。也许在 syslog 或 /var/log/messages 中有一些信息?顺便说一句,这个问题应该在不同的服务上被问到,例如askubuntu.comsuperuser.com,与编程无关。
  • 我可以在上面的日志中看到 Main PID: 18555 (code=exited, status=1/FAILURE) 这可能是关于 PID 文件的错误吗??
  • 退出代码 1 仅表示出现错误。您需要更多来自 Celery 的日志记录才能了解它崩溃的原因。您的问题似乎与您的 Celery 配置有关,而不是您的 systemd 配置。

标签: celery ubuntu-16.04 systemd


【解决方案1】:

我也有同样的症状,原来是权限问题。

在我的情况下是这样的:

chmod o+x /srv/weaver/src

排序了。

注意:这不是启用所需权限的最佳方式,但这与此答案无关。

【讨论】:

    【解决方案2】:

    我刚刚遇到了这个确切的问题。我的问题是配置问题。特别是,我没有设置 CELERYD_LOG_LEVEL 在我的环境文件中。 (/etc/default/celeryd 在你的情况下)。看来你也犯了同样的错误。

    (我还有一些其他配置问题需要解决。我通过在命令行上运行 celery 发现了这些问题。)

    【讨论】: