Handle keystoneauth exceptions in retry logic
The retry_logic in do_request catches neutronclient errors, but if a SessionClient is being used, nothing throws neutronclient errors - instead keystoneauth Session throws keystoneauth exceptions. Add the keystoneauth.exceptions.ConnectionError to the things that handle the error and retry. Change-Id: If16e50ee53279652fbdfc2d13d5509f46a54124a
This commit is contained in:
parent
3c2925a4de
commit
b8a05333dd
@ -22,6 +22,7 @@ import re
|
|||||||
import time
|
import time
|
||||||
|
|
||||||
import debtcollector.renames
|
import debtcollector.renames
|
||||||
|
from keystoneauth1 import exceptions as ksa_exc
|
||||||
import requests
|
import requests
|
||||||
import six.moves.urllib.parse as urlparse
|
import six.moves.urllib.parse as urlparse
|
||||||
from six import string_types
|
from six import string_types
|
||||||
@ -335,7 +336,7 @@ class ClientBase(object):
|
|||||||
try:
|
try:
|
||||||
return self.do_request(method, action, body=body,
|
return self.do_request(method, action, body=body,
|
||||||
headers=headers, params=params)
|
headers=headers, params=params)
|
||||||
except exceptions.ConnectionFailed:
|
except (exceptions.ConnectionFailed, ksa_exc.ConnectionError):
|
||||||
# Exception has already been logged by do_request()
|
# Exception has already been logged by do_request()
|
||||||
if i < self.retries:
|
if i < self.retries:
|
||||||
_logger.debug('Retrying connection to Neutron service')
|
_logger.debug('Retrying connection to Neutron service')
|
||||||
|
Loading…
x
Reference in New Issue
Block a user