启动celery beat的时候有这样一个报错,
(rpa2) E:rpa2>celery beat vx.x.x(版本号) (Cipater) is starting.
ERROR: Pidfile (celerybeat.pid) already exists.
Seems we're already running? (pid: 22220)
* Restarting with stat
原因追溯:
celery beat在运行时,会自动创建两个文件
pidfile:默认为celerybeat.pid,保存在项目根目录。
scheduler:默认为celerybeat-schedule,保存在项目根目录。
这里的报错说明pidfile已存在,以下是官方说明。
–pidfile
File used to store the process pid. Defaults to celerybeat.pid.
The program won’t start if this file already exists and the pid is still alive.
上次运行的时候,已经自动创建了,进程结束的时候并未自动删除,从而导致再次运行的时候报错了。
方法一:直接删除这个pidfile文件,再次启动celery beat -> 运行成功
方法二:如果在启动celery beat的时候配置pidfile参数,并将该参数设置为空,不会再生成该文件,可以规避这个问题。
celery beat -A celery_app -l info --pidfile=
总结
celery beat在运行时会生成一个pidfile文件用于记录当前的pid。且该文件不会因进程的结束而自动删除。当再次创建celery beat进程的时候,会因为已存在这个文件而启动失败。
解决方式有两种:
-
在启动前检测是否存在该文件,若存在删除后再启动
-
通过启动时指定空参数的方式规避:
celery -A manage.celery beat --pidfile=