diff options
author | szumka <106675199+szumka@users.noreply.github.com> | 2022-07-21 14:13:42 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2022-07-21 15:13:42 +0300 |
commit | 6a78773dee65c236e49b3edcda41be7d57649a23 (patch) | |
tree | a2222ae67a8d19ba304c01b9563656b1dc6040da /redis/asyncio/connection.py | |
parent | 4b0543d567aef36ac467ce495d831a24575d8d5b (diff) | |
download | redis-py-6a78773dee65c236e49b3edcda41be7d57649a23.tar.gz |
Use retry mechanism in async version of Connection objects (#2271)
Diffstat (limited to 'redis/asyncio/connection.py')
-rw-r--r-- | redis/asyncio/connection.py | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/redis/asyncio/connection.py b/redis/asyncio/connection.py index 35536fc..5bf2a0f 100644 --- a/redis/asyncio/connection.py +++ b/redis/asyncio/connection.py @@ -637,6 +637,8 @@ class Connection: retry_on_error = [] if retry_on_timeout: retry_on_error.append(TimeoutError) + retry_on_error.append(socket.timeout) + retry_on_error.append(asyncio.TimeoutError) self.retry_on_error = retry_on_error if retry_on_error: if not retry: @@ -706,7 +708,9 @@ class Connection: if self.is_connected: return try: - await self._connect() + await self.retry.call_with_retry( + lambda: self._connect(), lambda error: self.disconnect() + ) except asyncio.CancelledError: raise except (socket.timeout, asyncio.TimeoutError): |