summaryrefslogtreecommitdiff
path: root/redis/asyncio/connection.py
diff options
context:
space:
mode:
authorszumka <106675199+szumka@users.noreply.github.com>2022-07-21 14:13:42 +0200
committerGitHub <noreply@github.com>2022-07-21 15:13:42 +0300
commit6a78773dee65c236e49b3edcda41be7d57649a23 (patch)
treea2222ae67a8d19ba304c01b9563656b1dc6040da /redis/asyncio/connection.py
parent4b0543d567aef36ac467ce495d831a24575d8d5b (diff)
downloadredis-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.py6
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):