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


Python exception.DBConnectionError方法代碼示例

本文整理匯總了Python中oslo_db.exception.DBConnectionError方法的典型用法代碼示例。如果您正苦於以下問題:Python exception.DBConnectionError方法的具體用法?Python exception.DBConnectionError怎麽用?Python exception.DBConnectionError使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在oslo_db.exception的用法示例。


在下文中一共展示了exception.DBConnectionError方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: _test_connection

# 需要導入模塊: from oslo_db import exception [as 別名]
# 或者: from oslo_db.exception import DBConnectionError [as 別名]
def _test_connection(engine, max_retries, retry_interval):
    if max_retries == -1:
        attempts = itertools.count()
    else:
        attempts = range(max_retries)
    # See: http://legacy.python.org/dev/peps/pep-3110/#semantic-changes for
    # why we are not using 'de' directly (it can be removed from the local
    # scope).
    de_ref = None
    for attempt in attempts:
        try:
            return engine.connect()
        except exception.DBConnectionError as de:
            msg = 'SQL connection failed. %s attempts left.'
            LOG.warning(msg, max_retries - attempt)
            time.sleep(retry_interval)
            de_ref = de
    else:
        if de_ref is not None:
            raise de_ref 
開發者ID:openstack,項目名稱:oslo.db,代碼行數:22,代碼來源:engines.py

示例2: _raise_operational_errors_directly_filter

# 需要導入模塊: from oslo_db import exception [as 別名]
# 或者: from oslo_db.exception import DBConnectionError [as 別名]
def _raise_operational_errors_directly_filter(operational_error,
                                              match, engine_name,
                                              is_disconnect):
    """Filter for all remaining OperationalError classes and apply.

    Filter for all remaining OperationalError classes and apply
    special rules.
    """
    if is_disconnect:
        # operational errors that represent disconnect
        # should be wrapped
        raise exception.DBConnectionError(operational_error)
    else:
        # NOTE(comstud): A lot of code is checking for OperationalError
        # so let's not wrap it for now.
        raise operational_error 
開發者ID:openstack,項目名稱:oslo.db,代碼行數:18,代碼來源:exc_filters.py

示例3: __init__

# 需要導入模塊: from oslo_db import exception [as 別名]
# 或者: from oslo_db.exception import DBConnectionError [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

示例4: test_rollback_doesnt_interfere_with_killed_conn

# 需要導入模塊: from oslo_db import exception [as 別名]
# 或者: from oslo_db.exception import DBConnectionError [as 別名]
def test_rollback_doesnt_interfere_with_killed_conn(self):
        session = self.sessionmaker()

        session.begin()
        try:
            session.execute("select 1")

            # close underying DB connection
            session.connection().connection.connection.close()

            # alternate approach, but same idea:
            # conn_id = session.scalar("select connection_id()")
            # session.execute("kill connection %s" % conn_id)

            # try using it, will raise an error
            session.execute("select 1")
        except exception.DBConnectionError:
            # issue being tested is that this session.rollback()
            # does not itself try to re-connect and raise another
            # error.
            session.rollback()
        else:
            assert False, "no exception raised" 
開發者ID:openstack,項目名稱:oslo.db,代碼行數:25,代碼來源:test_exc_filters.py

示例5: test_savepoint_rollback_doesnt_interfere_with_killed_conn

# 需要導入模塊: from oslo_db import exception [as 別名]
# 或者: from oslo_db.exception import DBConnectionError [as 別名]
def test_savepoint_rollback_doesnt_interfere_with_killed_conn(self):
        session = self.sessionmaker()

        session.begin()
        try:
            session.begin_nested()
            session.execute("select 1")

            # close underying DB connection
            session.connection().connection.connection.close()

            # alternate approach, but same idea:
            # conn_id = session.scalar("select connection_id()")
            # session.execute("kill connection %s" % conn_id)

            # try using it, will raise an error
            session.execute("select 1")
        except exception.DBConnectionError:
            # issue being tested is that this session.rollback()
            # does not itself try to re-connect and raise another
            # error.
            session.rollback()
        else:
            assert False, "no exception raised" 
開發者ID:openstack,項目名稱:oslo.db,代碼行數:26,代碼來源:test_exc_filters.py

示例6: _api_raise

# 需要導入模塊: from oslo_db import exception [as 別名]
# 或者: from oslo_db.exception import DBConnectionError [as 別名]
def _api_raise(self, *args, **kwargs):
        """Simulate raising a database-has-gone-away error

        This method creates a fake OperationalError with an ID matching
        a valid MySQL "database has gone away" situation. It also decrements
        the error_counter so that we can artificially keep track of
        how many times this function is called by the wrapper. When
        error_counter reaches zero, this function returns True, simulating
        the database becoming available again and the query succeeding.
        """

        if self.error_counter > 0:
            self.error_counter -= 1
            orig = sqla.exc.DBAPIError(False, False, False)
            orig.args = [2006, 'Test raise operational error']
            e = exception.DBConnectionError(orig)
            raise e
        else:
            return True 
開發者ID:openstack,項目名稱:oslo.db,代碼行數:21,代碼來源:test_api.py

示例7: test_report_state_newly_disconnected

# 需要導入模塊: from oslo_db import exception [as 別名]
# 或者: from oslo_db.exception import DBConnectionError [as 別名]
def test_report_state_newly_disconnected(self):
        service_ref = {'host': self.host,
                       'binary': self.binary,
                       'topic': self.topic,
                       'report_count': 0,
                       'id': 1}
        with mock.patch.object(service, 'db') as mock_db:
            mock_db.service_get_by_args.side_effect = exception.NotFound()
            mock_db.service_create.return_value = service_ref
            mock_db.service_get.side_effect = db_exc.DBConnectionError()

            serv = service.Service(
                self.host,
                self.binary,
                self.topic,
                'karbor.tests.unit.test_service.FakeManager'
            )
            serv.start()
            serv.report_state()
            self.assertTrue(serv.model_disconnected)
            self.assertFalse(mock_db.service_update.called) 
開發者ID:openstack,項目名稱:karbor,代碼行數:23,代碼來源:test_service.py

示例8: test_health_check_stale_amphora

# 需要導入模塊: from oslo_db import exception [as 別名]
# 或者: from oslo_db.exception import DBConnectionError [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

示例9: _connect_ping_listener

# 需要導入模塊: from oslo_db import exception [as 別名]
# 或者: from oslo_db.exception import DBConnectionError [as 別名]
def _connect_ping_listener(connection, branch):
    """Ping the server at connection startup.

    Ping the server at transaction begin and transparently reconnect
    if a disconnect exception occurs.
    """
    if branch:
        return

    # turn off "close with result".  This can also be accomplished
    # by branching the connection, however just setting the flag is
    # more performant and also doesn't get involved with some
    # connection-invalidation awkardness that occurs (see
    # https://bitbucket.org/zzzeek/sqlalchemy/issue/3215/)
    save_should_close_with_result = connection.should_close_with_result
    connection.should_close_with_result = False
    try:
        # run a SELECT 1.   use a core select() so that
        # any details like that needed by Oracle, DB2 etc. are handled.
        connection.scalar(select([1]))
    except exception.DBConnectionError:
        # catch DBConnectionError, which is raised by the filter
        # system.
        # disconnect detected.  The connection is now
        # "invalid", but the pool should be ready to return
        # new connections assuming they are good now.
        # run the select again to re-validate the Connection.
        LOG.exception(
            'Database connection was found disconnected; reconnecting')
        connection.scalar(select([1]))
    finally:
        connection.should_close_with_result = save_should_close_with_result 
開發者ID:openstack,項目名稱:oslo.db,代碼行數:34,代碼來源:engines.py

示例10: _is_db_connection_error

# 需要導入模塊: from oslo_db import exception [as 別名]
# 或者: from oslo_db.exception import DBConnectionError [as 別名]
def _is_db_connection_error(operational_error, match, engine_name,
                            is_disconnect):
    """Detect the exception as indicating a recoverable error on connect."""
    raise exception.DBConnectionError(operational_error) 
開發者ID:openstack,項目名稱:oslo.db,代碼行數:6,代碼來源:exc_filters.py

示例11: _raise_for_remaining_DBAPIError

# 需要導入模塊: from oslo_db import exception [as 別名]
# 或者: from oslo_db.exception import DBConnectionError [as 別名]
def _raise_for_remaining_DBAPIError(error, match, engine_name, is_disconnect):
    """Filter for remaining DBAPIErrors.

    Filter for remaining DBAPIErrors and wrap if they represent
    a disconnect error.
    """
    if is_disconnect:
        raise exception.DBConnectionError(error)
    else:
        LOG.warning('DBAPIError exception wrapped.', exc_info=True)
        raise exception.DBError(error) 
開發者ID:openstack,項目名稱:oslo.db,代碼行數:13,代碼來源:exc_filters.py

示例12: test_generic_dbapi_disconnect

# 需要導入模塊: from oslo_db import exception [as 別名]
# 或者: from oslo_db.exception import DBConnectionError [as 別名]
def test_generic_dbapi_disconnect(self):
        matched = self._run_test(
            "mysql", "select the_db_disconnected",
            self.InterfaceError("connection lost"),
            exception.DBConnectionError,
            is_disconnect=True
        )
        self.assertInnerException(
            matched,
            "InterfaceError", "connection lost",
            "select the_db_disconnected", ()), 
開發者ID:openstack,項目名稱:oslo.db,代碼行數:13,代碼來源:test_exc_filters.py

示例13: test_operational_dbapi_disconnect

# 需要導入模塊: from oslo_db import exception [as 別名]
# 或者: from oslo_db.exception import DBConnectionError [as 別名]
def test_operational_dbapi_disconnect(self):
        matched = self._run_test(
            "mysql", "select the_db_disconnected",
            self.OperationalError("connection lost"),
            exception.DBConnectionError,
            is_disconnect=True
        )
        self.assertInnerException(
            matched,
            "OperationalError", "connection lost",
            "select the_db_disconnected", ()), 
開發者ID:openstack,項目名稱:oslo.db,代碼行數:13,代碼來源:test_exc_filters.py

示例14: test_connect_retry_stops_infailure

# 需要導入模塊: from oslo_db import exception [as 別名]
# 或者: from oslo_db.exception import DBConnectionError [as 別名]
def test_connect_retry_stops_infailure(self):
        self.assertRaises(
            exception.DBConnectionError,
            self._run_test,
            "mysql",
            self.OperationalError("Error: (2003) something wrong"),
            3, 2
        ) 
開發者ID:openstack,項目名稱:oslo.db,代碼行數:10,代碼來源:test_exc_filters.py

示例15: _test_ping_listener_disconnected

# 需要導入模塊: from oslo_db import exception [as 別名]
# 或者: from oslo_db.exception import DBConnectionError [as 別名]
def _test_ping_listener_disconnected(
            self, dialect_name, exc_obj, is_disconnect=True):
        with self._fixture(dialect_name, exc_obj, 3, is_disconnect):
            conn = self.engine.connect()
            self.assertEqual(1, conn.scalar(sqla.select([1])))
            conn.close()

        with self._fixture(dialect_name, exc_obj, 1, is_disconnect):
            self.assertRaises(
                exception.DBConnectionError,
                self.engine.connect
            )
            self.assertRaises(
                exception.DBConnectionError,
                self.engine.connect
            )
            self.assertRaises(
                exception.DBConnectionError,
                self.engine.connect
            )

        with self._fixture(dialect_name, exc_obj, 1, is_disconnect):
            self.assertRaises(
                exception.DBConnectionError,
                self.engine.connect
            )
            self.assertRaises(
                exception.DBConnectionError,
                self.engine.connect
            )
            self.assertRaises(
                exception.DBConnectionError,
                self.engine.connect
            ) 
開發者ID:openstack,項目名稱:oslo.db,代碼行數:36,代碼來源:test_exc_filters.py


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