Celery beat не возобновляет запланированные задачи django
Я использовал celery & django celery beat для запуска предопределенной запланированной задачи. Когда я сначала запускаю celery worker & затем celery beat worker, все в порядке, задача добавляется в базу данных, а также отправляется в очередь celery beat worker непрерывно.
Но когда я останавливаю beat worker и запускаю его снова, он больше не работает, хотя задача определена в базе данных.
Что мне делать?
Это мой код для django:
# Set the default Django settings module for the 'celery' program.
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'proj.settings')
app = Celery('proj')
# Using a string here means the worker doesn't have to serialize
# the configuration object to child processes.
# - namespace='CELERY' means all celery-related configuration keys
# should have a `CELERY_` prefix.
app.config_from_object('django.conf:settings', namespace='CELERY')
# Load task modules from all registered Django apps.
app.autodiscover_tasks()
@app.task
def test(arg):
print(arg)
@app.on_after_configure.connect
def setup_periodic_tasks(sender, **kwargs):
# Calls test('hello') every 10 seconds.
sender.add_periodic_task(10.0, test.s('hello'), name='say hello every 10 secs')
app.conf.beat_schedule = {
'add-every-12-seconds': {
'task': 'tasks.test',
'schedule': 12.0,
# 'args': ()
},
}
и вот как я запускаю celery worker & beat worker:
celery -A proj worker -l info
celery -A proj beat -l INFO --scheduler django_celery_beat.schedulers:DatabaseScheduler
Буду признателен за помощь...
В прошлом я сталкивался с подобной проблемой с Django и Celery. Однако в моем случае проблема заключалась в том, что когда рабочий был закрыт, рабочий процесс не завершился успешно. Поэтому, когда был запущен новый рабочий процесс, он вступил в конфликт с уже запущенным процессом и привел к тому, что задачи не выполнялись, как ожидалось. Необходимо проверить, не запущен ли еще какой-либо рабочий процесс после его закрытия:
ps aux | grep python
.