ERROR: Pidfile (celerybeat.pid) already exists.

启动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=

     

你可能感兴趣的:(celery)