Django-q:超时后警告转世的 worker Process-1:1

Django-q: WARNING reincarnated worker Process-1:1 after timeout

提问人:Sandy 提问时间:5/10/2021 更新时间:3/23/2022 访问量:1184

问:

我已经安装并配置了 Django-Q 1.3.5(在带有 Redis 3.5.3 和 Python 3.8.5 的 Django 3.2 上)。 这是我的集群配置:

# redis defaults
Q_CLUSTER = {
    'name': 'my_broker',
    'workers': 4,
    'recycle': 500,
    'timeout': 60,
    'retry': 65,
    'compress': True,
    'save_limit': 250,
    'queue_limit': 500,
    'cpu_affinity': 1,
    'redis': {
        'host': 'localhost',
        'port': 6379,
        'db': 0,
        'password': None,
        'socket_timeout': None,
        'charset': 'utf-8',
        'errors': 'strict',
        'unix_socket_path': None
    }
}

我适当地选择并解释我的问题。 我创建了这个简单的函数来通过 Admin Scheduled Task 调用:timeout:60retry:65

def test_timeout_task():
    time.sleep(61)
    return "Result of task"

这是我的“计划任务页面”(localhost:8000/admin/django_q/schedule/)

编号 名字 功能 成功
1 测试超时 mymodel.tasks.test_timeout_task ?

当我运行此任务时,我收到以下警告:

10:18:21 [Q] INFO Process-1 created a task from schedule [test timeout]
10:19:22 [Q] WARNING reincarnated worker Process-1:1 after timeout
10:19:22 [Q] INFO Process-1:7 ready for work at 68301

并且不再执行任务。

所以,我的问题是:有没有办法正确处理不可预测的任务?

django django-q django-redis

评论


答:

0赞 Enigmind 3/23/2022 #1

您可以将超时设置为 :,它应该在不停止的情况下处理您的任务。'timeout': None