本文整理匯總了Python中pymongo.errors.PyMongoError方法的典型用法代碼示例。如果您正苦於以下問題:Python errors.PyMongoError方法的具體用法?Python errors.PyMongoError怎麽用?Python errors.PyMongoError使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類pymongo.errors
的用法示例。
在下文中一共展示了errors.PyMongoError方法的14個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: connect
# 需要導入模塊: from pymongo import errors [as 別名]
# 或者: from pymongo.errors import PyMongoError [as 別名]
def connect(self):
"""Connect to MongoDB"""
if self.__conn is None:
if self.mongo_user is None:
try:
self.__conn = MongoClient('mongodb://%s:%s' %
(self.mongo_host,
self.mongo_port))
except errors.PyMongoError as py_mongo_error:
print('Error in MongoDB connection: %s' %
str(py_mongo_error))
else:
try:
self.__conn = MongoClient('mongodb://%s:%s@%s:%s' %
(self.mongo_user,
self.mongo_password,
self.mongo_host,
self.mongo_port))
except errors.PyMongoError as py_mongo_error:
print('Error in MongoDB connection: %s' %
str(py_mongo_error))
示例2: with_retry
# 需要導入模塊: from pymongo import errors [as 別名]
# 或者: from pymongo.errors import PyMongoError [as 別名]
def with_retry(tries):
def outer_wrapper(f):
@wraps(f)
def inner_wrapper(*args, **kwargs):
def _retry(t=tries):
if t <= 0:
logger.error("unable to write hit to database")
# raise WriteError(f"unable to write to database")
return
try:
f(*args, **kwargs)
except PyMongoError:
t -= 1
_retry(t)
return _retry()
return inner_wrapper
return outer_wrapper
示例3: deprovision_mongo
# 需要導入模塊: from pymongo import errors [as 別名]
# 或者: from pymongo.errors import PyMongoError [as 別名]
def deprovision_mongo(self, ignore_errors=False):
"""
Drop Mongo databases.
"""
self.logger.info('Deprovisioning Mongo started.')
database_url = self._get_main_database_url()
if database_url and self.mongo_provisioned:
mongo = pymongo.MongoClient(database_url)
for database in self.mongo_database_names:
# Dropping a non-existing database is a no-op. Users are dropped together with the DB.
self.logger.info('Dropping mongo db: %s.', database)
try:
mongo.drop_database(database)
except PyMongoError as exc:
self.logger.exception('Cannot drop Mongo database: %s. %s', database, exc)
if not ignore_errors:
raise
self.mongo_provisioned = False
self.save()
self.logger.info('Deprovisioning Mongo finished.')
示例4: update_analysis_tags
# 需要導入模塊: from pymongo import errors [as 別名]
# 或者: from pymongo.errors import PyMongoError [as 別名]
def update_analysis_tags(self, uid, plugin_name, tag_name, tag):
firmware_object = self.get_object(uid=uid, analysis_filter=[])
try:
tags = update_tags(firmware_object.analysis_tags, plugin_name, tag_name, tag)
except ValueError as value_error:
logging.error('Plugin {} tried setting a bad tag {}: {}'.format(plugin_name, tag_name, str(value_error)))
return None
except AttributeError:
logging.error('Firmware not in database yet: {}'.format(uid))
return None
if isinstance(firmware_object, Firmware):
try:
self.firmwares.update_one({'_id': uid}, {'$set': {'analysis_tags': tags}})
except (TypeError, ValueError, PyMongoError) as exception:
logging.error('Could not update firmware: {} - {}'.format(type(exception), str(exception)))
else:
logging.warning('Propagating tag only allowed for firmware. Given: {}')
示例5: test_authenticate_fails_exception
# 需要導入模塊: from pymongo import errors [as 別名]
# 或者: from pymongo.errors import PyMongoError [as 別名]
def test_authenticate_fails_exception():
db = create_autospec(Database)
db.authenticate.side_effect = PyMongoError("error")
with pytest.raises(PyMongoError):
assert auth.authenticate(db, sentinel.user, sentinel.password) is False
示例6: get_maintenance
# 需要導入模塊: from pymongo import errors [as 別名]
# 或者: from pymongo.errors import PyMongoError [as 別名]
def get_maintenance(self):
"""get replica set maintenance info"""
if self.__conn is None:
self.connect()
db_handler = self.__conn
fsync_locked = int(db_handler.is_locked)
self.add_metrics('mongodb.fsync-locked', fsync_locked)
try:
config = db_handler.admin.command("replSetGetConfig", 1)
connstring = (self.mongo_host + ':' + str(self.mongo_port))
connstrings = list()
for i in range(0, len(config['config']['members'])):
host = config['config']['members'][i]['host']
connstrings.append(host)
if connstring in host:
priority = config['config']['members'][i]['priority']
hidden = int(config['config']['members'][i]['hidden'])
self.add_metrics('mongodb.priority', priority)
self.add_metrics('mongodb.hidden', hidden)
except errors.PyMongoError:
print ('Error while fetching replica set configuration.'
'Not a member of replica set?')
except UnboundLocalError:
print ('Cannot use this mongo host: must be one of ' + ','.join(connstrings))
exit(1)
示例7: mongodb_error_log
# 需要導入模塊: from pymongo import errors [as 別名]
# 或者: from pymongo.errors import PyMongoError [as 別名]
def mongodb_error_log(func):
def wrapper(*args, **kwargs):
try:
return func(*args, **kwargs)
except PyMongoError as err:
tb_content = ' '.join(traceback.format_exception(*sys.exc_info()))
msg = (
'\nOperate Mongodb error! \n Func: {}, args: {}, kwargs: {} '
'\n Error: {} \n {}'
).format(func.__name__, args, kwargs, err, tb_content)
logger.error(msg)
raise DBError(msg)
except InvalidId as err:
logger.error('Invalid BSON ObjectId: {}'.format(err))
return wrapper
示例8: get_mongo_client
# 需要導入模塊: from pymongo import errors [as 別名]
# 或者: from pymongo.errors import PyMongoError [as 別名]
def get_mongo_client(host, port=27017):
"""
Returns a ``Deferred`` which fires with a ``MongoClient`` when one has been
created.
See http://api.mongodb.org/python/current/api/pymongo/mongo_client.html#
pymongo.mongo_client.MongoClient
for more parameter information.
:param bytes host: Hostname or IP address of the instance to connect to.
:param int port: Port number on which to connect.
The tutorial says "If you get a connection refused error try again after a
few seconds; the application might take some time to fully start up."
and so here we wait until the client can be created.
"""
def create_mongo_client():
try:
client = MongoClient(host=host, port=port)
client.areyoualive.posts.insert({"ping": 1})
return client
except PyMongoError:
return False
d = loop_until(reactor, create_mongo_client)
return d
示例9: connect
# 需要導入模塊: from pymongo import errors [as 別名]
# 或者: from pymongo.errors import PyMongoError [as 別名]
def connect(self):
"""
Connect to the Mongo database.
"""
try:
self.connection = MongoClient(host=self.host, port=self.port)
except PyMongoError:
if self.fail_silently:
return
else:
raise
self.database = self.connection[self.database_name]
self.collection = self.database[self.collection_name]
示例10: _get_without_uid
# 需要導入模塊: from pymongo import errors [as 別名]
# 或者: from pymongo.errors import PyMongoError [as 別名]
def _get_without_uid(self):
try:
query = get_query(request.args)
offset, limit = get_paging(request.args)
except ValueError as value_error:
request_data = {k: request.args.get(k) for k in ['query', 'limit', 'offset']}
return error_message(str(value_error), self.URL, request_data=request_data)
parameters = dict(offset=offset, limit=limit, query=query)
try:
with ConnectTo(FrontEndDbInterface, self.config) as connection:
uids = connection.rest_get_file_object_uids(**parameters)
return success_message(dict(uids=uids), self.URL, parameters)
except PyMongoError:
return error_message('Unknown exception on request', self.URL, parameters)
示例11: _get_without_uid
# 需要導入模塊: from pymongo import errors [as 別名]
# 或者: from pymongo.errors import PyMongoError [as 別名]
def _get_without_uid(self):
try:
query, recursive, inverted, offset, limit = self._get_parameters_from_request(request.args)
except ValueError as value_error:
request_data = {k: request.args.get(k) for k in ['query', 'limit', 'offset', 'recursive', 'inverted']}
return error_message(str(value_error), self.URL, request_data=request_data)
parameters = dict(offset=offset, limit=limit, query=query, recursive=recursive, inverted=inverted)
try:
with ConnectTo(FrontEndDbInterface, self.config) as connection:
uids = connection.rest_get_firmware_uids(**parameters)
return success_message(dict(uids=uids), self.URL, parameters)
except PyMongoError:
return error_message('Unknown exception on request', self.URL, parameters)
示例12: add_compare_result
# 需要導入模塊: from pymongo import errors [as 別名]
# 或者: from pymongo.errors import PyMongoError [as 別名]
def add_compare_result(self, compare_result):
compare_result['_id'] = self._calculate_compare_result_id(compare_result)
compare_result['submission_date'] = time()
with suppress(PyMongoError):
self.compare_results.delete_one({'_id': compare_result['_id']})
self.compare_results.insert_one(compare_result)
logging.info('compare result added to db: {}'.format(compare_result['_id']))
示例13: init_users
# 需要導入模塊: from pymongo import errors [as 別名]
# 或者: from pymongo.errors import PyMongoError [as 別名]
def init_users(self):
logging.info('Creating users for MongoDB authentication')
if self.auth_is_enabled():
logging.error("The DB seems to be running with authentication. Try terminating the MongoDB process.")
mongo_server = self.config['data_storage']['mongo_server']
mongo_port = self.config['data_storage']['mongo_port']
try:
client = MongoClient('mongodb://{}:{}'.format(mongo_server, mongo_port), connect=False)
client.admin.command(
"createUser",
self.config['data_storage']['db_admin_user'],
pwd=self.config['data_storage']['db_admin_pw'],
roles=[
{'role': 'dbOwner', 'db': 'admin'},
{'role': 'readWriteAnyDatabase', 'db': 'admin'},
{'role': 'root', 'db': "admin"}
]
)
client.admin.command(
"createUser",
self.config['data_storage']['db_readonly_user'],
pwd=self.config['data_storage']['db_readonly_pw'],
roles=[{'role': 'readAnyDatabase', 'db': 'admin'}]
)
except (AttributeError, ValueError, errors.PyMongoError) as error:
logging.error('Could not create users:\n{}'.format(error))
示例14: _run_consuming_function_with_confirm_and_retry
# 需要導入模塊: from pymongo import errors [as 別名]
# 或者: from pymongo.errors import PyMongoError [as 別名]
def _run_consuming_function_with_confirm_and_retry(self, kw: dict, current_retry_times,
function_result_status: FunctionResultStatus, ):
function_only_params = _delete_keys_and_return_new_dict(kw['body'])
if current_retry_times < self.__get_priority_conf(kw, 'max_retry_times'):
function_result_status.run_times += 1
# noinspection PyBroadException
t_start = time.time()
try:
function_run = self.consuming_function if self._function_timeout == 0 else self._concurrent_mode_dispatcher.timeout_deco(
self.__get_priority_conf(kw, 'function_timeout'))(self.consuming_function)
if self._is_consuming_function_use_multi_params: # 消費函數使用傳統的多參數形式
function_result_status.result = function_run(**function_only_params)
else:
function_result_status.result = function_run(
function_only_params) # 消費函數使用單個參數,參數自身是一個字典,由鍵值對表示各個參數。
function_result_status.success = True
self._confirm_consume(kw)
if self.__get_priority_conf(kw, 'do_task_filtering'):
self._redis_filter.add_a_value(function_only_params) # 函數執行成功後,添加函數的參數排序後的鍵值對字符串到set中。
self.logger.debug(f' 函數 {self.consuming_function.__name__} '
f'第{current_retry_times + 1}次 運行, 正確了,函數運行時間是 {round(time.time() - t_start, 4)} 秒,入參是 【 {function_only_params} 】。 {ConsumersManager.get_concurrent_info()}')
except Exception as e:
if isinstance(e, (PyMongoError,
ExceptionForRequeue)): # mongo經常維護備份時候插入不了或掛了,或者自己主動拋出一個ExceptionForRequeue類型的錯誤會重新入隊,不受指定重試次數逇約束。
self.logger.critical(f'函數 [{self.consuming_function.__name__}] 中發生錯誤 {type(e)} {e},消息重新入隊')
time.sleep(1) # 防止快速無限出錯入隊出隊,導致cpu和中間件忙
return self._requeue(kw)
self.logger.error(f'函數 {self.consuming_function.__name__} 第{current_retry_times + 1}次發生錯誤,'
f'函數運行時間是 {round(time.time() - t_start, 4)} 秒,\n 入參是 【 {function_only_params} 】 \n 原因是 {type(e)} {e} ',
exc_info=self.__get_priority_conf(kw, 'is_print_detail_exception'))
function_result_status.exception = f'{e.__class__.__name__} {str(e)}'
return self._run_consuming_function_with_confirm_and_retry(kw, current_retry_times + 1, function_result_status, )
else:
self.logger.critical(
f'函數 {self.consuming_function.__name__} 達到最大重試次數 {self.__get_priority_conf(kw, "max_retry_times")} 後,仍然失敗, 入參是 【 {function_only_params} 】')
self._confirm_consume(kw) # 錯得超過指定的次數了,就確認消費了。
if self.__get_priority_conf(kw, 'is_using_rpc_mode'):
# print(function_result_status.get_status_dict(without_datetime_obj=True))
with RedisMixin().redis_db_frame.pipeline() as p:
# RedisMixin().redis_db_frame.lpush(kw['body']['extra']['task_id'], json.dumps(function_result_status.get_status_dict(without_datetime_obj=True)))
# RedisMixin().redis_db_frame.expire(kw['body']['extra']['task_id'], 600)
p.lpush(kw['body']['extra']['task_id'],
json.dumps(function_result_status.get_status_dict(without_datetime_obj=True)))
p.expire(kw['body']['extra']['task_id'], 600)
p.execute()
self._result_persistence_helper.save_function_result_to_mongo(function_result_status)