python - 如何为 celery 后端连接添加重试?

标签 python redis celery

我正在使用celery 5.0.1并将CELERY_BACKEND_URL用作redis://:password@redisinstance1:6379/0。它可以正常工作,但是当Redis实例连接松动时,它会因出错而中断任务。

Exception: Error while reading from socket: (104, 'Connection reset by peer')
Traceback (most recent call last):
  File "/usr/local/lib/python3.7/dist-packages/redis/connection.py", line 198, in _read_from_socket
    data = recv(self._sock, socket_read_size)
  File "/usr/local/lib/python3.7/dist-packages/redis/_compat.py", line 72, in recv
    return sock.recv(*args, **kwargs)
ConnectionResetError: [Errno 104] Connection reset by peer

During handling of the above exception, another exception occurred:

Traceback (most recent call last):
  File "/usr/local/lib/python3.7/dist-packages/celery/app/trace.py", line 477, in trace_task
    uuid, retval, task_request, publish_result,
  File "/usr/local/lib/python3.7/dist-packages/celery/backends/base.py", line 154, in mark_as_done
    self.store_result(task_id, result, state, request=request)
  File "/usr/local/lib/python3.7/dist-packages/celery/backends/base.py", line 439, in store_result
    request=request, **kwargs)
  File "/usr/local/lib/python3.7/dist-packages/celery/backends/base.py", line 855, in _store_result
    current_meta = self._get_task_meta_for(task_id)
  File "/usr/local/lib/python3.7/dist-packages/celery/backends/base.py", line 873, in _get_task_meta_for
    meta = self.get(self.get_key_for_task(task_id))
  File "/usr/local/lib/python3.7/dist-packages/celery/backends/redis.py", line 346, in get
    return self.client.get(key)
  File "/usr/local/lib/python3.7/dist-packages/redis/client.py", line 1606, in get
    return self.execute_command('GET', name)
  File "/usr/local/lib/python3.7/dist-packages/redis/client.py", line 901, in execute_command
    return self.parse_response(conn, command_name, **options)
  File "/usr/local/lib/python3.7/dist-packages/redis/client.py", line 915, in parse_response
    response = connection.read_response()
  File "/usr/local/lib/python3.7/dist-packages/redis/connection.py", line 739, in read_response
    response = self._parser.read_response()
  File "/usr/local/lib/python3.7/dist-packages/redis/connection.py", line 324, in read_response
    raw = self._buffer.readline()
  File "/usr/local/lib/python3.7/dist-packages/redis/connection.py", line 256, in readline
    self._read_from_socket()
  File "/usr/local/lib/python3.7/dist-packages/redis/connection.py", line 223, in _read_from_socket
    (ex.args,))
redis.exceptions.ConnectionError: Error while reading from socket: (104, 'Connection reset by peer')


Celery worker: None
Celery task id: 244b56af-7c96-56cf-a01a-9256cfd98ade
Celery retry attempt: 0
Task args: []
Task kwargs: {'address': 'ipadd', 'uid': 'uid', 'hexID': 'hexID', 'taskID': '244b56af-7c96-56cf-a01a-9256cfd98ade'}
当我运行第二个任务时,它运行良好,在短时间内连接中存在一些故障。
我可以设置一些方法,当celery尝试将结果更新为Redis时,如果返回错误,它将在2-5秒后重试?
我知道如何在任务中设置重试,但这不会导致任务失败。我的任务工作正常,它返回数据,但是celery在更新到后端时失去连接。

最佳答案

要处理connection timeouts,您可以在Celery配置中包含以下内容:

app.conf.broker_transport_options = {
    'retry_policy': {
       'timeout': 5.0
    }
}
app.conf.result_backend_transport_options = {
    'retry_policy': {
       'timeout': 5.0
    }
}
您可能要考虑在配置中添加其他Redis backend settings,例如redis_retry_on_timeout

关于python - 如何为 celery 后端连接添加重试?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/64445015/

相关文章:

python - Pandas 、numpy.where() 和 numpy.nan

Redis事务和watch命令

python - CANT_REREAD : Format string in Celery . %h

python - celery 花在主管管理下不工作

python - 动态访问 pandas 数据框的子集,执行计算并写入新数据框

Python 2.5 到 Python 2.2 转换器

python - 字典中的范围函数

redis - BLPOP 和 MISCONF 配置 Redis 保存 RDB 快照

redis - 使用 Booksleeve 将字节数组键序列化到 Redis 的最佳方法

python - 查询python memcached数据