本文整理匯總了Python中oslo_db.exception.RetryRequest方法的典型用法代碼示例。如果您正苦於以下問題:Python exception.RetryRequest方法的具體用法?Python exception.RetryRequest怎麽用?Python exception.RetryRequest使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類oslo_db.exception
的用法示例。
在下文中一共展示了exception.RetryRequest方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: __init__
# 需要導入模塊: from oslo_db import exception [as 別名]
# 或者: from oslo_db.exception import RetryRequest [as 別名]
def __init__(self, retry_interval=1, max_retries=20,
inc_retry_interval=True,
max_retry_interval=10, retry_on_disconnect=False,
retry_on_deadlock=False,
exception_checker=lambda exc: False,
jitter=False):
super(wrap_db_retry, self).__init__()
self.jitter = jitter
self.db_error = (exception.RetryRequest, )
# default is that we re-raise anything unexpected
self.exception_checker = exception_checker
if retry_on_disconnect:
self.db_error += (exception.DBConnectionError, )
if retry_on_deadlock:
self.db_error += (exception.DBDeadlock, )
self.retry_interval = retry_interval
self.max_retries = max_retries
self.inc_retry_interval = inc_retry_interval
self.max_retry_interval = max_retry_interval
示例2: reraise_as_retryrequest
# 需要導入模塊: from oslo_db import exception [as 別名]
# 或者: from oslo_db.exception import RetryRequest [as 別名]
def reraise_as_retryrequest(function):
"""Wrap the said function with a RetryRequest upon error.
:param function: The function to wrap/decorate.
:returns: The 'function' wrapped in a try block that will reraise any
Exception's as a RetryRequest.
:raises RetryRequest: If the wrapped function raises retriable exception.
"""
@functools.wraps(function)
def _wrapped(*args, **kwargs):
try:
return function(*args, **kwargs)
except Exception as e:
with excutils.save_and_reraise_exception() as ctx:
if is_retriable(e):
ctx.reraise = False
raise db_exc.RetryRequest(e)
return _wrapped
示例3: exc_to_retry
# 需要導入模塊: from oslo_db import exception [as 別名]
# 或者: from oslo_db.exception import RetryRequest [as 別名]
def exc_to_retry(etypes):
"""Contextually reraise Exceptions as a RetryRequests.
:param etypes: The class type to check the exception for.
:returns: None
:raises: A RetryRequest if any exception is caught in the context
is a nested instance of etypes.
"""
try:
yield
except Exception as e:
with excutils.save_and_reraise_exception() as ctx:
if _is_nested_instance(e, etypes):
ctx.reraise = False
raise db_exc.RetryRequest(e)
# for convenient access as decorators
示例4: test_health_check_stale_amphora
# 需要導入模塊: from oslo_db import exception [as 別名]
# 或者: from oslo_db.exception import RetryRequest [as 別名]
def test_health_check_stale_amphora(self, session_mock, get_stale_amp_mock,
failover_mockv2, failover_mock,
db_wait_mock):
conf = oslo_fixture.Config(cfg.CONF)
conf.config(group="health_manager", heartbeat_timeout=5)
amphora_health = mock.MagicMock()
amphora_health.amphora_id = AMPHORA_ID
get_stale_amp_mock.side_effect = [amphora_health, None]
exit_event = threading.Event()
hm = healthmanager.HealthManager(exit_event)
hm.health_check()
# Test DBDeadlock and RetryRequest exceptions
session_mock.reset_mock()
get_stale_amp_mock.reset_mock()
mock_session = mock.MagicMock()
session_mock.return_value = mock_session
get_stale_amp_mock.side_effect = [
db_exc.DBDeadlock,
db_exc.RetryRequest(Exception('retry_test')),
db_exc.DBConnectionError,
TestException('test')]
# Test that a DBDeadlock does not raise an exception
self.assertIsNone(hm.health_check())
# Test that a RetryRequest does not raise an exception
self.assertIsNone(hm.health_check())
# Test that a DBConnectionError does not raise an exception
self.assertIsNone(hm.health_check())
# ... and that it waits for DB reconnection
db_wait_mock.assert_called_once()
# Other exceptions should raise
self.assertRaises(TestException, hm.health_check)
self.assertEqual(4, mock_session.rollback.call_count)
示例5: record
# 需要導入模塊: from oslo_db import exception [as 別名]
# 或者: from oslo_db.exception import RetryRequest [as 別名]
def record(plugin_context, object_type, object_uuid, operation, data,
ml2_context=None):
if (object_type == odl_const.ODL_PORT and
operation in (odl_const.ODL_CREATE, odl_const.ODL_UPDATE)):
data = _enrich_port(
plugin_context, ml2_context, object_type, operation, data)
# Calculate depending_on on other journal entries
depending_on = dependency_validations.calculate(
plugin_context, operation, object_type, object_uuid, data)
# NOTE(mpeterson): Between the moment that a dependency is calculated and
# the new entry is recorded in the journal, an operation can ocurr that
# would make the dependency irrelevant. In that case we request a retry.
# For more details, read the commit message that introduced this comment.
try:
entry = db.create_pending_row(
plugin_context, object_type, object_uuid, operation, data,
depending_on=depending_on)
except exception.DBReferenceError as e:
raise exception.RetryRequest(e)
_log_entry(LOG_RECORDED, entry)
LOG.debug('Entry with ID %(entry_id)s depends on these entries: '
'%(depending_on)s',
{'entry_id': entry.seqnum,
'depending_on': [d.seqnum for d in depending_on]})
示例6: test_record_triggers_retry_on_reference_error
# 需要導入模塊: from oslo_db import exception [as 別名]
# 或者: from oslo_db.exception import RetryRequest [as 別名]
def test_record_triggers_retry_on_reference_error(self, mock_create_row,
mock_calculate):
args = [mock.Mock(unsafe=True)] * 5
self.assertRaises(exception.RetryRequest, journal.record, *args)
示例7: _lock_free_update
# 需要導入模塊: from oslo_db import exception [as 別名]
# 或者: from oslo_db.exception import RetryRequest [as 別名]
def _lock_free_update(session, uuid, lock_state=False, session_id=0):
"""Implement lock-free atomic update for the distributed lock
:param session: the db session
:type session: DB Session object
:param uuid: the lock uuid
:type uuid: string
:param lock_state: the lock state to update
:type lock_state: boolean
:param session_id: the API session ID to update
:type session_id: string
:raises RetryRequest(): when the lock failed to update
"""
if not lock_state:
# acquire lock
search_params = {'object_uuid': uuid, 'lock': lock_state}
update_params = {'lock': not lock_state, 'session_id': session_id}
else:
# release or reset lock
search_params = {'object_uuid': uuid, 'lock': lock_state,
'session_id': session_id}
update_params = {'lock': not lock_state, 'session_id': 0}
rows_update = session.query(models.DFLockedObjects).\
filter_by(**search_params).\
update(update_params, synchronize_session='fetch')
if not rows_update:
LOG.debug('The lock for object %(id)s in session '
'%(sid)s cannot be updated.', {'id': uuid,
'sid': session_id})
raise db_exc.RetryRequest(df_exc.DBLockFailed(oid=uuid,
sid=session_id))
示例8: retry_on_request
# 需要導入模塊: from oslo_db import exception [as 別名]
# 或者: from oslo_db.exception import RetryRequest [as 別名]
def retry_on_request(f):
"""Retry a DB API call if RetryRequest exception was received.
wrap_db_entry will be applied to all db.api functions marked with this
decorator.
"""
f.__dict__['enable_retry_on_request'] = True
return f
示例9: _is_exception_expected
# 需要導入模塊: from oslo_db import exception [as 別名]
# 或者: from oslo_db.exception import RetryRequest [as 別名]
def _is_exception_expected(self, exc):
if isinstance(exc, self.db_error):
# RetryRequest is application-initated exception
# and not an error condition in case retries are
# not exceeded
if not isinstance(exc, exception.RetryRequest):
LOG.debug('DB error: %s', exc)
return True
return self.exception_checker(exc)
示例10: test_retry_wrapper_reaches_limit
# 需要導入模塊: from oslo_db import exception [as 別名]
# 或者: from oslo_db.exception import RetryRequest [as 別名]
def test_retry_wrapper_reaches_limit(self):
max_retries = 2
@api.wrap_db_retry(max_retries=max_retries)
def some_method(res):
res['result'] += 1
raise exception.RetryRequest(ValueError())
res = {'result': 0}
self.assertRaises(ValueError, some_method, res)
self.assertEqual(max_retries + 1, res['result'])
示例11: is_retriable
# 需要導入模塊: from oslo_db import exception [as 別名]
# 或者: from oslo_db.exception import RetryRequest [as 別名]
def is_retriable(exception):
"""Determine if the said exception is retriable.
:param exception: The exception to check.
:returns: True if 'exception' is retriable, otherwise False.
"""
if _is_nested_instance(exception,
(db_exc.DBDeadlock, exc.StaleDataError,
db_exc.DBConnectionError,
db_exc.DBDuplicateEntry, db_exc.RetryRequest)):
return True
# Look for savepoints mangled by deadlocks. See bug/1590298 for details.
return (_is_nested_instance(exception, db_exc.DBError) and
'1305' in str(exception))
示例12: is_retriable
# 需要導入模塊: from oslo_db import exception [as 別名]
# 或者: from oslo_db.exception import RetryRequest [as 別名]
def is_retriable(e):
"""Determine if the exception is retriable.
:param e: The exception to check.
:returns: True if e is retriable and False otherwise.
"""
if getattr(e, '_RETRY_EXCEEDED', False):
return False
if _is_nested_instance(e, (db_exc.DBDeadlock, exc.StaleDataError,
db_exc.DBConnectionError,
db_exc.DBDuplicateEntry, db_exc.RetryRequest,
obj_exc.NeutronDbObjectDuplicateEntry)):
return True
# looking savepoints mangled by deadlocks. see bug/1590298 for details.
return _is_nested_instance(e, db_exc.DBError) and '1305' in str(e)
示例13: test_translates_single_exception
# 需要導入模塊: from oslo_db import exception [as 別名]
# 或者: from oslo_db.exception import RetryRequest [as 別名]
def test_translates_single_exception(self):
with testtools.ExpectedException(db_exc.RetryRequest):
with db_api.exc_to_retry(ValueError):
raise ValueError()
示例14: test_translates_DBerror_inner_exception
# 需要導入模塊: from oslo_db import exception [as 別名]
# 或者: from oslo_db.exception import RetryRequest [as 別名]
def test_translates_DBerror_inner_exception(self):
with testtools.ExpectedException(db_exc.RetryRequest):
with db_api.exc_to_retry(ValueError):
raise db_exc.DBError(ValueError())
示例15: test_inner_exception_preserved_in_retryrequest
# 需要導入模塊: from oslo_db import exception [as 別名]
# 或者: from oslo_db.exception import RetryRequest [as 別名]
def test_inner_exception_preserved_in_retryrequest(self):
try:
exc = ValueError('test')
with db_api.exc_to_retry(ValueError):
raise exc
except db_exc.RetryRequest as e:
self.assertEqual(exc, e.inner_exc)