Merge "NSX|V: Add log messages to retry attempts"

This commit is contained in:
Jenkins 2017-09-11 23:15:31 +00:00 committed by Gerrit Code Review
commit 5030e7dc41

View File

@ -13,6 +13,9 @@
# License for the specific language governing permissions and limitations # License for the specific language governing permissions and limitations
# under the License. # under the License.
import inspect
import re
from distutils import version from distutils import version
import functools import functools
import hashlib import hashlib
@ -21,6 +24,7 @@ import xml.etree.ElementTree as et
import eventlet import eventlet
import six import six
import tenacity import tenacity
from tenacity import _utils as tenacity_utils
from neutron import version as n_version from neutron import version as n_version
from neutron_lib.api import validators from neutron_lib.api import validators
@ -145,6 +149,39 @@ def _get_bad_request_error_code(e):
pass pass
def _log_before_retry(func, trial_number):
"""Before call strategy that logs to some logger the attempt."""
if trial_number > 1:
LOG.warning("Retrying call to '%(func)s' for the %(num)s time",
{'func': tenacity_utils.get_callback_name(func),
'num': tenacity_utils.to_ordinal(trial_number)})
def _get_args_from_frame(frames, frame_num):
if len(frames) > frame_num and frames[frame_num] and frames[frame_num][0]:
argvalues = inspect.getargvalues(frames[frame_num][0])
formated_args = inspect.formatargvalues(*argvalues)
# remove the first 'self' arg from the log as it adds no information
formated_args = re.sub(r'\(self=.*?, ', "(", formated_args)
return formated_args
def _log_after_retry(func, trial_number, trial_time_taken):
"""After call strategy that logs to some logger the finished attempt."""
# Using inspect to get arguments of the relevant call
frames = inspect.trace()
formated_args = _get_args_from_frame(frames, 1)
if not formated_args:
formated_args = "Unknown"
LOG.warning("Finished retry of %(func)s for the %(num)s time after "
"%(time)0.3f(s) with args: %(args)s",
{'func': tenacity_utils.get_callback_name(func),
'num': tenacity_utils.to_ordinal(trial_number),
'time': trial_time_taken,
'args': formated_args})
def retry_upon_exception_exclude_error_codes( def retry_upon_exception_exclude_error_codes(
exc, excluded_errors, delay, max_delay, max_attempts): exc, excluded_errors, delay, max_delay, max_attempts):
"""Retry with the configured exponential delay, unless the exception error """Retry with the configured exponential delay, unless the exception error
@ -164,7 +201,8 @@ def retry_upon_exception_exclude_error_codes(
retry_if_not_error_codes), retry_if_not_error_codes),
wait=tenacity.wait_exponential( wait=tenacity.wait_exponential(
multiplier=delay, max=max_delay), multiplier=delay, max=max_delay),
stop=tenacity.stop_after_attempt(max_attempts)) stop=tenacity.stop_after_attempt(max_attempts),
before=_log_before_retry, after=_log_after_retry)
def retry_upon_exception(exc, delay, max_delay, max_attempts): def retry_upon_exception(exc, delay, max_delay, max_attempts):
@ -172,7 +210,8 @@ def retry_upon_exception(exc, delay, max_delay, max_attempts):
retry=tenacity.retry_if_exception_type(exc), retry=tenacity.retry_if_exception_type(exc),
wait=tenacity.wait_exponential( wait=tenacity.wait_exponential(
multiplier=delay, max=max_delay), multiplier=delay, max=max_delay),
stop=tenacity.stop_after_attempt(max_attempts)) stop=tenacity.stop_after_attempt(max_attempts),
before=_log_before_retry, after=_log_after_retry)
def read_file(path): def read_file(path):