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


Python errors.PyMongoError方法代碼示例

本文整理匯總了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)) 
開發者ID:omni-lchen,項目名稱:zabbix-mongodb,代碼行數:23,代碼來源:zabbix-mongodb.py

示例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 
開發者ID:clarketm,項目名稱:s3recon,代碼行數:22,代碼來源:mongodb.py

示例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.') 
開發者ID:open-craft,項目名稱:opencraft,代碼行數:22,代碼來源:database.py

示例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: {}') 
開發者ID:fkie-cad,項目名稱:FACT_core,代碼行數:20,代碼來源:db_interface_backend.py

示例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 
開發者ID:man-group,項目名稱:arctic,代碼行數:7,代碼來源:test_auth.py

示例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) 
開發者ID:omni-lchen,項目名稱:zabbix-mongodb,代碼行數:32,代碼來源:zabbix-mongodb.py

示例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 
開發者ID:momosecurity,項目名稱:aswan,代碼行數:17,代碼來源:permission.py

示例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 
開發者ID:ClusterHQ,項目名稱:flocker,代碼行數:28,代碼來源:testtools.py

示例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] 
開發者ID:DistrictDataLabs,項目名稱:baleen,代碼行數:16,代碼來源:mongolog.py

示例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) 
開發者ID:fkie-cad,項目名稱:FACT_core,代碼行數:17,代碼來源:rest_file_object.py

示例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) 
開發者ID:fkie-cad,項目名稱:FACT_core,代碼行數:16,代碼來源:rest_firmware.py

示例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'])) 
開發者ID:fkie-cad,項目名稱:FACT_core,代碼行數:9,代碼來源:db_interface_compare.py

示例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)) 
開發者ID:fkie-cad,項目名稱:FACT_core,代碼行數:28,代碼來源:MongoMgr.py

示例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) 
開發者ID:ydf0509,項目名稱:distributed_framework,代碼行數:48,代碼來源:base_consumer.py


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