有没有办法为工作人员指定“最大”= inf 超时?我有一些长期运行的任务,如果由于超时而失败,我会在工作人员内部处理它。
可以通过cli指定吗?
有没有办法为工作人员指定“最大”= inf 超时?我有一些长期运行的任务,如果由于超时而失败,我会在工作人员内部处理它。
可以通过cli指定吗?
设置Queue(default_timeout=-1)
会解决问题。以下是对他们源代码的引用:
def create_job(self, func, args=None, kwargs=None, timeout=None,
result_ttl=None, ttl=None, failure_ttl=None,
description=None, depends_on=None, job_id=None,
meta=None, status=JobStatus.QUEUED, retry=None):
"""Creates a job based on parameters given."""
timeout = parse_timeout(timeout)
if timeout is None:
timeout = self._default_timeout
elif timeout == 0:
raise ValueError('0 timeout is not allowed. Use -1 for infinite timeout')
timeout 参数指定任务在被认为“丢失”之前的最大运行时间。可以与@job、Queue、enqueue 和 enqueue_call 一起使用。
from rq.decorators import job
@job('low', connection=my_redis_conn, timeout=600)
def long_running_task(x, y):
# Code