當前位置: 首頁>>代碼示例>>Python>>正文


Python exception.RetryRequest方法代碼示例

本文整理匯總了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 
開發者ID:openstack,項目名稱:oslo.db,代碼行數:22,代碼來源:api.py

示例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 
開發者ID:openstack,項目名稱:neutron-lib,代碼行數:20,代碼來源:utils.py

示例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 
開發者ID:openstack,項目名稱:neutron-lib,代碼行數:20,代碼來源:api.py

示例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) 
開發者ID:openstack,項目名稱:octavia,代碼行數:38,代碼來源:test_health_manager.py

示例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]}) 
開發者ID:openstack,項目名稱:networking-odl,代碼行數:29,代碼來源:journal.py

示例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) 
開發者ID:openstack,項目名稱:networking-odl,代碼行數:6,代碼來源:test_journal.py

示例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)) 
開發者ID:openstack,項目名稱:dragonflow,代碼行數:35,代碼來源:lockedobjects_db.py

示例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 
開發者ID:openstack,項目名稱:oslo.db,代碼行數:10,代碼來源:api.py

示例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) 
開發者ID:openstack,項目名稱:oslo.db,代碼行數:11,代碼來源:api.py

示例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']) 
開發者ID:openstack,項目名稱:oslo.db,代碼行數:13,代碼來源:test_api.py

示例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)) 
開發者ID:openstack,項目名稱:neutron-lib,代碼行數:16,代碼來源:utils.py

示例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) 
開發者ID:openstack,項目名稱:neutron-lib,代碼行數:17,代碼來源:api.py

示例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() 
開發者ID:openstack,項目名稱:neutron-lib,代碼行數:6,代碼來源:test_api.py

示例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()) 
開發者ID:openstack,項目名稱:neutron-lib,代碼行數:6,代碼來源:test_api.py

示例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) 
開發者ID:openstack,項目名稱:neutron-lib,代碼行數:9,代碼來源:test_api.py


注:本文中的oslo_db.exception.RetryRequest方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。