[英]How can to run task in 5 minutes after finish previous task using celery-beat?
[英]How can to start tasks with celery-beat?
为什么我不能运行定期任务?
项目/settings.py
REDIS_HOST = 'localhost'
REDIS_PORT = '6379'
CELERY_BROKER_URL = 'redis://localhost:6379'
BROKER_URL = 'redis://' + REDIS_HOST + ':' + REDIS_PORT
CELERY_BEAT_SCHEDULE = {
'task-first': {
'task': 'app.tasks.one',
'schedule': timedelta(seconds=1)
},
'task-second': {
'task': 'app.tasks.two',
'schedule': crontab(minute=0, hour='*/3,10-19')
}
}
项目/芹菜.py
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'proj.settings')
app = Celery('proj')
app.config_from_object('django.conf:settings')
app.autodiscover_tasks(lambda: settings.INSTALLED_APPS)
项目/__init.py__
from .celery import app as celery_app
__all__ = ['celery_app']
celery -A 项目工人 -l 信息
[2019-10-31 16:57:57,906: INFO/MainProcess] Connected to redis://localhost:6379//
[2019-10-31 16:57:57,912: INFO/MainProcess] mingle: searching for neighbors
[2019-10-31 16:57:58,927: INFO/MainProcess] mingle: all alone
[2019-10-31 16:57:58,951: INFO/MainProcess] celery@lexvel-MS-7A72 ready.
找到任务
celery -A 项目节拍 -l 信息
Configuration ->
. broker -> redis://localhost:6379//
. loader -> celery.loaders.app.AppLoader
. scheduler -> celery.beat.PersistentScheduler
. db -> celerybeat-schedule
. logfile -> [stderr]@%INFO
. maxinterval -> 5.00 minutes (300s)
[2019-10-31 16:58:02,851: INFO/MainProcess] beat: Starting...
创建celerybeat-shedule
文件。 但除了这些行之外,什么也没有显示。
任务
@task()
def one():
print('start 1', datetime.now())
driver = init_driver()
parse(driver)
driver.close()
driver.quit()
@task()
def two():
print('start 2', datetime.now())
driver = init_driver()
parse2(driver)
driver.close()
driver.quit()
print('end 2', datetime.now())
celery -A proj worker -l info -B --scheduler django_celery_beat.schedulers:DatabaseScheduler
此命令用于启动 celery 节拍。
首先在设置文件的已安装应用程序中添加django_celery_beat
模块。
然后应用 django migrate
命令,这将在管理面板中创建表。
完成 celery 文件中的所有过程后,在tasks.py
中创建任务。
您将应用上面提到的 beat 命令。
项目/settings.py
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'django_celery_beat',
]
REDIS_URL = "redis://localhost:6379/1"
CELERY_BROKER_URL=REDIS_URL
CELERY_RESULT_BACKEND=REDIS_URL
CELERY_ACCEPT_CONTENT = ['application/json']
CELERY_RESULT_SERIALIZER = 'json'
CELERY_TASK_SERIALIZER = 'json'
CELERY_BEAT_SCHEDULE = {
'task-first': {
'task': 'app.tasks.one',
'schedule': timedelta(seconds=1)
},
'task-second': {
'task': 'app.tasks.two',
'schedule': crontab(minute=0, hour='*/3,10-19')
}
}
项目/芹菜.py
from celery import Celery
from django.conf import settings
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'proj.settings')
app = Celery('proj')
app.config_from_object('django.conf:settings')
app.autodiscover_tasks(lambda: settings.INSTALLED_APPS)
项目/__init.py__
from .celery import app as celery_app
**__all__** = ['celery_app']
当你运行你的工人时,它是否说app.tasks.one
和app.tasks.two
是注册任务? 如果它们没有作为已注册任务出现在那里,那么您的节拍就是安排无法执行的任务。 - 他们只会在队列中等待,并最终过期。 检查是否已注册的另一种方法是通过celery -A proj.celeryapp inspect registered
(将proj.celeryapp
更改为 Celery 应用程序的位置)。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.