本文整理匯總了Python中pymongo.errors.ServerSelectionTimeoutError方法的典型用法代碼示例。如果您正苦於以下問題:Python errors.ServerSelectionTimeoutError方法的具體用法?Python errors.ServerSelectionTimeoutError怎麽用?Python errors.ServerSelectionTimeoutError使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類pymongo.errors
的用法示例。
在下文中一共展示了errors.ServerSelectionTimeoutError方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: select_server_by_address
# 需要導入模塊: from pymongo import errors [as 別名]
# 或者: from pymongo.errors import ServerSelectionTimeoutError [as 別名]
def select_server_by_address(self, address,
server_selection_timeout=None):
"""Return a Server for "address", reconnecting if necessary.
If the server's type is not known, request an immediate check of all
servers. Time out after "server_selection_timeout" if the server
cannot be reached.
:Parameters:
- `address`: A (host, port) pair.
- `server_selection_timeout` (optional): maximum seconds to wait.
If not provided, the default value
common.SERVER_SELECTION_TIMEOUT is used.
Calls self.open() if needed.
Raises exc:`ServerSelectionTimeoutError` after
`server_selection_timeout` if no matching servers are found.
"""
return self.select_server(any_server_selector,
server_selection_timeout,
address)
示例2: wait_for_ok_and_master
# 需要導入模塊: from pymongo import errors [as 別名]
# 或者: from pymongo.errors import ServerSelectionTimeoutError [as 別名]
def wait_for_ok_and_master(module, connection_params, timeout = 180):
start_time = dtdatetime.now()
while True:
try:
client = MongoClient(**connection_params)
authenticate(client, connection_params["username"], connection_params["password"])
status = client.admin.command('replSetGetStatus', check=False)
if status['ok'] == 1 and status['myState'] == 1:
return
except ServerSelectionTimeoutError:
pass
client.close()
if (dtdatetime.now() - start_time).seconds > timeout:
module.fail_json(msg='reached timeout while waiting for rs.status() to become ok=1')
time.sleep(1)
示例3: db_connect
# 需要導入模塊: from pymongo import errors [as 別名]
# 或者: from pymongo.errors import ServerSelectionTimeoutError [as 別名]
def db_connect():
maxSevSelDelay = 1
try:
mongo_host = 'localhost'
mongo_port = 27017
if 'MONGO_PORT_27017_TCP_ADDR' in os.environ :
mongo_host = os.environ['MONGO_PORT_27017_TCP_ADDR']
if 'MONGO_PORT_27017_TCP_PORT' in os.environ:
mongo_port = int(os.environ['MONGO_PORT_27017_TCP_PORT'])
client = MongoClient(mongo_host, mongo_port, serverSelectionTimeoutMS=maxSevSelDelay)
client.server_info()
return client
except ServerSelectionTimeoutError as err:
exit("Failed to connect to MongoDB.")
示例4: setUpClass
# 需要導入模塊: from pymongo import errors [as 別名]
# 或者: from pymongo.errors import ServerSelectionTimeoutError [as 別名]
def setUpClass(cls):
"""
Instantiate the adapter before any tests in the test case run.
"""
from pymongo.errors import ServerSelectionTimeoutError
from pymongo import MongoClient
cls.has_mongo_connection = False
try:
client = MongoClient(
serverSelectionTimeoutMS=0.1
)
client.server_info()
cls.adapter = MongoDatabaseAdapter(
database_uri='mongodb://localhost:27017/chatterbot_test_database'
)
cls.has_mongo_connection = True
except ServerSelectionTimeoutError:
pass
示例5: init_database
# 需要導入模塊: from pymongo import errors [as 別名]
# 或者: from pymongo.errors import ServerSelectionTimeoutError [as 別名]
def init_database(self):
"""
Initializes the database connection to MongoDB.
Also pre-caches potentially heavy resources from the DB.
:return:
"""
self.log.info('Connecting to Database...')
self.db = Database(self, self.cfg.db)
try:
await self.db[self.db.db_nam].collection.find_one({})
if self.cfg.cache.type not in ['redis', 'mixed']:
await self.db.precache_settings()
await self.db.precache_profiles()
await self.db.precache_resources()
set_color_cache_coll(self.db[self.db.db_nam].ColorCache)
except ServerSelectionTimeoutError:
self.log.error('A Connection To The Database Host Failed!')
exit(errno.ETIMEDOUT)
except OperationFailure:
self.log.error('Database Access Operation Failed!')
exit(errno.EACCES)
self.log.info('Successfully Connected to Database')
示例6: gather_configured_members_ips
# 需要導入模塊: from pymongo import errors [as 別名]
# 或者: from pymongo.errors import ServerSelectionTimeoutError [as 別名]
def gather_configured_members_ips(mongo_tasks_ips, mongo_port):
current_ips = set()
logger = logging.getLogger(__name__)
for t in mongo_tasks_ips:
mc = pm.MongoClient(t, mongo_port)
try:
config = mc.admin.command("replSetGetConfig")['config']
for m in config['members']:
current_ips.add(m['host'].split(":")[0])
# Let's accept the first configuration found. Read as room for improvement!
break
except ServerSelectionTimeoutError as ssete:
logger.debug("cannot connect to {} to get configuration, failed ({})".format(t,ssete))
except OperationFailure as of:
logger.debug("no configuration found in node {} ({})".format(t,of))
finally:
mc.close()
logger.debug("Current members in mongo configurations: {}".format(current_ips))
return current_ips
示例7: get_primary_ip
# 需要導入模塊: from pymongo import errors [as 別名]
# 或者: from pymongo.errors import ServerSelectionTimeoutError [as 別名]
def get_primary_ip(tasks_ips, mongo_port):
logger = logging.getLogger(__name__)
primary_ips = []
for t in tasks_ips:
mc = pm.MongoClient(t, mongo_port)
try:
if mc.is_primary:
primary_ips.append(t)
except ServerSelectionTimeoutError as ssete:
logger.debug("cannot connect to {} check if primary, failed ({})".format(t,ssete))
except OperationFailure as of:
logger.debug("no configuration found in node {} ({})".format(t,of))
finally:
mc.close()
if len(primary_ips) > 1:
logger.warning("Multiple primaries were found ({}). Let's use the first.".format(primary_ips))
if primary_ips:
logger.info("Primary is: {}".format(primary_ips[0]))
return primary_ips[0]
示例8: test_ServerSelectionTimeoutError_no_retry
# 需要導入模塊: from pymongo import errors [as 別名]
# 或者: from pymongo.errors import ServerSelectionTimeoutError [as 別名]
def test_ServerSelectionTimeoutError_no_retry():
error = ServerSelectionTimeoutError('some error')
with patch('arctic.decorators._log_exception', autospec=True) as le:
@mongo_retry
def foo():
raise error
with pytest.raises(ServerSelectionTimeoutError) as e:
foo()
assert 'some error' in str(e.value)
assert le.call_count == 1
示例9: select_servers
# 需要導入模塊: from pymongo import errors [as 別名]
# 或者: from pymongo.errors import ServerSelectionTimeoutError [as 別名]
def select_servers(self,
selector,
server_selection_timeout=None,
address=None):
"""Return a list of Servers matching selector, or time out.
:Parameters:
- `selector`: function that takes a list of Servers and returns
a subset of them.
- `server_selection_timeout` (optional): maximum seconds to wait.
If not provided, the default value common.SERVER_SELECTION_TIMEOUT
is used.
- `address`: optional server address to select.
Calls self.open() if needed.
Raises exc:`ServerSelectionTimeoutError` after
`server_selection_timeout` if no matching servers are found.
"""
if server_selection_timeout is None:
server_timeout = self._settings.server_selection_timeout
else:
server_timeout = server_selection_timeout
with self._lock:
server_descriptions = self._select_servers_loop(
selector, server_timeout, address)
return [self.get_server_by_address(sd.address)
for sd in server_descriptions]
示例10: _select_servers_loop
# 需要導入模塊: from pymongo import errors [as 別名]
# 或者: from pymongo.errors import ServerSelectionTimeoutError [as 別名]
def _select_servers_loop(self, selector, timeout, address):
"""select_servers() guts. Hold the lock when calling this."""
now = _time()
end_time = now + timeout
server_descriptions = self._description.apply_selector(
selector, address)
while not server_descriptions:
# No suitable servers.
if timeout == 0 or now > end_time:
raise ServerSelectionTimeoutError(
self._error_message(selector))
self._ensure_opened()
self._request_check_all()
# Release the lock and wait for the topology description to
# change, or for a timeout. We won't miss any changes that
# came after our most recent apply_selector call, since we've
# held the lock until now.
self._condition.wait(common.MIN_HEARTBEAT_INTERVAL)
self._description.check_compatible()
now = _time()
server_descriptions = self._description.apply_selector(
selector, address)
self._description.check_compatible()
return server_descriptions
示例11: connect
# 需要導入模塊: from pymongo import errors [as 別名]
# 或者: from pymongo.errors import ServerSelectionTimeoutError [as 別名]
def connect(self):
try:
logging.debug("Getting MongoDB connection to %s (replicaSet=%s, readPreference=%s, readPreferenceTags=%s, ssl=%s)" % (
self.uri,
self.replset,
self.read_pref,
self.do_rp_tags,
self.do_ssl(),
))
conn = MongoClient(**self.client_opts())
if self.do_connect:
conn['admin'].command({"ping": 1})
except (ConfigurationError, ConnectionFailure, OperationFailure, ServerSelectionTimeoutError), e:
logging.error("Unable to connect to %s! Error: %s" % (self.uri, e))
raise DBConnectionError(e)
示例12: is_connected
# 需要導入模塊: from pymongo import errors [as 別名]
# 或者: from pymongo.errors import ServerSelectionTimeoutError [as 別名]
def is_connected(self):
try:
self.client.server_info()
except ServerSelectionTimeoutError:
return False
return True
示例13: create_mongo_connection
# 需要導入模塊: from pymongo import errors [as 別名]
# 或者: from pymongo.errors import ServerSelectionTimeoutError [as 別名]
def create_mongo_connection(self, hostname="localhost"):
"""
Creates a connection to YETI's MongoDB.
:param hostname: Hostname to connect to. Default is "localhost"
:return: None
"""
try:
# Try connecting to MongoDB for 10ms
self.mongo_client = MongoClient('mongodb://{}:27017/'.format(hostname), serverSelectionTimeoutMS=10)
self.mongo_client.server_info()
except errors.ServerSelectionTimeoutError as mongo_conn_err:
logger.exception(("MongoDB connection issue occurred. "
"Error message: " + str(mongo_conn_err)))
sys.exit(1)
示例14: setUp
# 需要導入模塊: from pymongo import errors [as 別名]
# 或者: from pymongo.errors import ServerSelectionTimeoutError [as 別名]
def setUp(self):
self.db_name = 'test_mongo_storage'
connection_string = 'mongodb://127.0.0.1:27017/?serverSelectionTimeoutMS=100'
try:
self.client = Mongo(connection_string, db_name=self.db_name,
collection='test')
list(self.client.get_all({}))
except ServerSelectionTimeoutError as e:
raise SkipTest(str(e))
示例15: _select_servers_loop
# 需要導入模塊: from pymongo import errors [as 別名]
# 或者: from pymongo.errors import ServerSelectionTimeoutError [as 別名]
def _select_servers_loop(self, selector, timeout, address):
"""select_servers() guts. Hold the lock when calling this."""
now = _time()
end_time = now + timeout
server_descriptions = self._description.apply_selector(
selector, address, custom_selector=self._settings.server_selector)
while not server_descriptions:
# No suitable servers.
if timeout == 0 or now > end_time:
raise ServerSelectionTimeoutError(
self._error_message(selector))
self._ensure_opened()
self._request_check_all()
# Release the lock and wait for the topology description to
# change, or for a timeout. We won't miss any changes that
# came after our most recent apply_selector call, since we've
# held the lock until now.
self._condition.wait(common.MIN_HEARTBEAT_INTERVAL)
self._description.check_compatible()
now = _time()
server_descriptions = self._description.apply_selector(
selector, address,
custom_selector=self._settings.server_selector)
self._description.check_compatible()
return server_descriptions