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


Python exceptions.InfluxDBClientError方法代碼示例

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


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

示例1: open

# 需要導入模塊: from influxdb import exceptions [as 別名]
# 或者: from influxdb.exceptions import InfluxDBClientError [as 別名]
def open(self):
       """
       Connect to InfluxDB cluster.
       """
       try:
           self.cc = InfluxDBClusterClient(hosts = self.hosts,
                               username=self.influxdb_user,
                               password=self.influxdb_passwd,
                               ssl=self.influxdb_ssl,
                               verify_ssl=self.influxdb_verify_ssl)

           self.is_connected = CONNECTED

       except InfluxDBClientError as e:
           logging.warning("Connection failed: %s" % e)
           return False

       return True 
開發者ID:descrepes,項目名稱:grafana-telegraf-dashboard-generator,代碼行數:20,代碼來源:generator.py

示例2: write_dataframe_to_idb

# 需要導入模塊: from influxdb import exceptions [as 別名]
# 或者: from influxdb.exceptions import InfluxDBClientError [as 別名]
def write_dataframe_to_idb(self, ticker):
        """Write Pandas Dataframe to InfluxDB database"""
        cachepath = self._cache
        cachefile = ('%s/%s-1M.csv.gz' % (cachepath, ticker))

        if not os.path.exists(cachefile):
            log.warn('Import file does not exist: %s' %
                     (cachefile))
            return

        df = pd.read_csv(cachefile, compression='infer', header=0,
                         infer_datetime_format=True)

        df['Datetime'] = pd.to_datetime(df['Date'] + ' ' + df['Time'])
        df = df.set_index('Datetime')
        df = df.drop(['Date', 'Time'], axis=1)

        try:
            self.dfdb.write_points(df, ticker)
        except InfluxDBClientError as err:
            log.error('Write to database failed: %s' % err) 
開發者ID:mementum,項目名稱:backtrader,代碼行數:23,代碼來源:influxdb-import.py

示例3: send_metrics

# 需要導入模塊: from influxdb import exceptions [as 別名]
# 或者: from influxdb.exceptions import InfluxDBClientError [as 別名]
def send_metrics(self, metrics):
        if not self.enable_metrics:
            return
        now = str(datetime.now())
        payload = []
        for metric, value in metrics.items():
            data = {
                'measurement': self.appname,
                'tags': {},
                'time': now,
                'fields': {
                    metric: value
                }
            }
            if self.extra_tags:
                data['tags'].update(self.extra_tags)
            payload.append(data)

        try:
            self.client.write_points(payload)
        except (RequestException, InfluxDBClientError, InfluxDBServerError):
            logger.exception('Failed to send metrics to influxdb') 
開發者ID:linkedin,項目名稱:iris,代碼行數:24,代碼來源:influx.py

示例4: _create_influxdb_writer

# 需要導入模塊: from influxdb import exceptions [as 別名]
# 或者: from influxdb.exceptions import InfluxDBClientError [as 別名]
def _create_influxdb_writer(influxdb_client, tags):
    """ Returns function which writes to influxdb

    Parameters
    ----------
    influxdb_client:
    """

    def to_influxdf(data_list, retries=5, pause=5):
        logger = _logger()
        logger.debug(data_list)
        for i in range(retries):
            try:
                if influxdb_client.write_points(data_list, tags=tags):
                    logger.debug("Success")
                    break
                else:
                    sleep(pause)
            except InfluxDBClientError:
                logger.debug('Failed {} out of {}'.format(i, retries))
        else:
            logger.warning("Failed to write to Database")

    return to_influxdf 
開發者ID:msalvaris,項目名稱:gpu_monitor,代碼行數:26,代碼來源:gpu_logger.py

示例5: init_database

# 需要導入模塊: from influxdb import exceptions [as 別名]
# 或者: from influxdb.exceptions import InfluxDBClientError [as 別名]
def init_database(self):
        """
        Initialize the InfluxDB database if it is not already there
        """
        try:
            logging.info("Creating InfluxDB database if not exists: %s",
                         self.config.influxdb_dbname)
            self.writer.create_database(self.config.influxdb_dbname)
        except ConnectionError as error:
            logging.error(
                "Connection error while trying to create InfluxDB database: %s. Waiting for retry...", error)
            time.sleep(self.db_create_delay)
            self.init_database()
        except (InfluxDBServerError, InfluxDBClientError) as error:
            logging.warning(
                "Could not create InfluxDB database. Assuming it already exists: %s", error) 
開發者ID:mre,項目名稱:kafka-influxdb,代碼行數:18,代碼來源:worker.py

示例6: flush

# 需要導入模塊: from influxdb import exceptions [as 別名]
# 或者: from influxdb.exceptions import InfluxDBClientError [as 別名]
def flush(self):
        """
        Flush values with writer
        """
        if not self.buffer:
            # Don't do anything when buffer empty
            return
        try:
            self.last_flush_time = time.time()
            self.writer.write(self.buffer)
            if self.config.statistics:
                self.show_statistics()
        except (InfluxDBServerError, InfluxDBClientError) as influx_error:
            logging.error("Error while writing to InfluxDB: %s", influx_error)
        finally:
            self.buffer = [] 
開發者ID:mre,項目名稱:kafka-influxdb,代碼行數:18,代碼來源:worker.py

示例7: initDb

# 需要導入模塊: from influxdb import exceptions [as 別名]
# 或者: from influxdb.exceptions import InfluxDBClientError [as 別名]
def initDb(self, client):
        try:
            client.create_database(influx_config.influx_db)
        except InfluxDBClientError:
            return

    # We have to rewrite the packet structure since
    # for influxdb, the tags and fields in a packet must be in the form of:

    # packet = {
    #    tags : {
    #        tagname1: tagValue,
    #        tagname2: tagValue,
    #        .
    #        .
    #    },
    #    time: ..... ,
    #    fields : {
    #        ssid: ...,
    #        mac_addr_src:....,
    #        .
    #        .
    #        value: .....
    #    }
    # } 
開發者ID:probr,項目名稱:probr-core,代碼行數:27,代碼來源:handlers.py

示例8: execute_influxdb

# 需要導入模塊: from influxdb import exceptions [as 別名]
# 或者: from influxdb.exceptions import InfluxDBClientError [as 別名]
def execute_influxdb(self, query):
        """
        Execute an InfluxDB query for the corpus

        Parameters
        ----------
        query : str
            Query to run

        Returns
        -------
        :class:`influxdb.resultset.ResultSet`
            Results of the query
        """
        client = self.acoustic_client()
        try:
            result = client.query(query)
        except InfluxDBClientError:
            print('There was an issue with the following query:')
            print(query)
            raise
        return result 
開發者ID:MontrealCorpusTools,項目名稱:PolyglotDB,代碼行數:24,代碼來源:audio.py

示例9: make_reset_measurement

# 需要導入模塊: from influxdb import exceptions [as 別名]
# 或者: from influxdb.exceptions import InfluxDBClientError [as 別名]
def make_reset_measurement(self):

        @pytest.fixture(scope="function")
        def reset_measurement():
            logger.info('InfluxDB: Resetting database')
            # Clear out the database.
            influx = InfluxWrapper(database=self.database, measurement=self.measurement)
            influx.client.delete_series(self.database, measurement=self.measurement)
            #try:
            #except InfluxDBClientError as ex:
            #    if 'database not found: mqttkit_1_itest' not in ex.message:
            #        raise

        return reset_measurement 
開發者ID:daq-tools,項目名稱:kotori,代碼行數:16,代碼來源:util.py

示例10: get_historical_minute_data

# 需要導入模塊: from influxdb import exceptions [as 別名]
# 或者: from influxdb.exceptions import InfluxDBClientError [as 別名]
def get_historical_minute_data(self, ticker: str):
        """Request historical 5 minute data from DTN."""
        start = self._start
        stop = self._stop

        if len(stop) > 4:
            stop = stop[:4]

        if len(start) > 4:
            start = start[:4]

        for year in range(int(start), int(stop) + 1):
            beg_time = ('%s0101000000' % year)
            end_time = ('%s1231235959' % year)
            msg = "HIT,%s,60,%s,%s,,,,1,,,s\r\n" % (ticker,
                                                    beg_time,
                                                    end_time)
            try:
                data = iq.iq_query(message=msg)
                iq.add_data_to_df(data=data)
            except Exception as err:
                log.error('No data returned because %s', err)

        try:
            self.dfdb.write_points(self._ndf, ticker)
        except InfluxDBClientError as err:
            log.error('Write to database failed: %s' % err) 
開發者ID:mementum,項目名稱:backtrader,代碼行數:29,代碼來源:iqfeed-to-influxdb.py

示例11: _write_points

# 需要導入模塊: from influxdb import exceptions [as 別名]
# 或者: from influxdb.exceptions import InfluxDBClientError [as 別名]
def _write_points(points, num_points):
    """
    Write the points to the InfluxDB in groups that are MAX_POINTS_PER_WRITE in
    size.
    """
    LOG.debug("Writing points %d", num_points)
    write_index = 0
    points_written = 0
    while write_index < num_points:
        max_write_index = write_index + MAX_POINTS_PER_WRITE
        write_points = points[write_index:max_write_index]
        try:
            g_client.write_points(write_points)
            points_written += len(write_points)
        except InfluxDBServerError as svr_exc:
            LOG.error(
                "InfluxDBServerError: %s\nFailed to write points: %s",
                str(svr_exc),
                _get_point_names(write_points),
            )
        except InfluxDBClientError as client_exc:
            LOG.error(
                "InfluxDBClientError writing points: %s\n" "Error: %s",
                _get_point_names(write_points),
                str(client_exc),
            )
        except requests.exceptions.ConnectionError as req_exc:
            LOG.error(
                "ConnectionError exception caught writing points: %s\n" "Error: %s",
                _get_point_names(write_points),
                str(req_exc),
            )
        write_index += MAX_POINTS_PER_WRITE

    return points_written 
開發者ID:Isilon,項目名稱:isilon_data_insights_connector,代碼行數:37,代碼來源:influxdb_plugin.py

示例12: get_listen_count_for_user

# 需要導入模塊: from influxdb import exceptions [as 別名]
# 或者: from influxdb.exceptions import InfluxDBClientError [as 別名]
def get_listen_count_for_user(self, user_name, need_exact=False):
        """Get the total number of listens for a user. The number of listens comes from
           brainzutils cache unless an exact number is asked for.

        Args:
            user_name: the user to get listens for
            need_exact: if True, get an exact number of listens directly from the ListenStore
        """

        if not need_exact:
            # check if the user's listen count is already in cache
            # if already present return it directly instead of calculating it again
            # decode is set to False as we have not encoded the value when we set it
            # in brainzutils cache as we need to call increment operation which requires
            # an integer value
            user_key = '{}{}'.format(REDIS_INFLUX_USER_LISTEN_COUNT, user_name)
            count = cache.get(user_key, decode=False)
            if count:
                return int(count)

        try:
            results = self.influx.query('SELECT count(*) FROM ' + get_escaped_measurement_name(user_name))
        except (InfluxDBServerError, InfluxDBClientError) as e:
            self.log.error("Cannot query influx: %s" % str(e), exc_info=True)
            raise

        # get the number of listens from the json
        try:
            count = results.get_points(measurement = get_measurement_name(user_name)).__next__()['count_recording_msid']
        except (KeyError, StopIteration):
            count = 0

        # put this value into brainzutils cache with an expiry time
        user_key = "{}{}".format(REDIS_INFLUX_USER_LISTEN_COUNT, user_name)
        cache.set(user_key, int(count), InfluxListenStore.USER_LISTEN_COUNT_CACHE_TIME, encode=False)
        return int(count) 
開發者ID:metabrainz,項目名稱:listenbrainz-server,代碼行數:38,代碼來源:influx_listenstore.py

示例13: delete

# 需要導入模塊: from influxdb import exceptions [as 別名]
# 或者: from influxdb.exceptions import InfluxDBClientError [as 別名]
def delete(self, musicbrainz_id):
        """ Delete all listens for user with specified MusicBrainz ID.

        Note: this method tries to delete the user 5 times before giving up.

        Args:
            musicbrainz_id (str): the MusicBrainz ID of the user

        Raises: Exception if unable to delete the user in 5 retries
        """
        for _ in range(5):
            try:
                self.influx.drop_measurement(get_measurement_name(musicbrainz_id))
                break
            except InfluxDBClientError as e:
                # influxdb-python raises client error if measurement isn't found
                # so we have to handle that case.
                if 'measurement not found' in e.content:
                    return
                else:
                    self.log.error('Error in influx client while dropping user %s: %s', musicbrainz_id, str(e), exc_info=True)
                    time.sleep(3)
            except InfluxDBServerError as e:
                self.log.error('Error in influx server while dropping user %s: %s', musicbrainz_id, str(e), exc_info=True)
                time.sleep(3)
            except Exception as e:
                self.log.error('Error while trying to drop user %s: %s', musicbrainz_id, str(e), exc_info=True)
                time.sleep(3)
        else:
            raise InfluxListenStoreException("Couldn't delete user with MusicBrainz ID: %s" % musicbrainz_id) 
開發者ID:metabrainz,項目名稱:listenbrainz-server,代碼行數:32,代碼來源:influx_listenstore.py

示例14: query

# 需要導入模塊: from influxdb import exceptions [as 別名]
# 或者: from influxdb.exceptions import InfluxDBClientError [as 別名]
def query(self, query):
        while True:
            try:
                return self.influx.query(query)
            except InfluxDBClientError as e:
                self.log.error("Client error while querying influx: %s", str(e), exc_info=True)
                time.sleep(1)
            except InfluxDBServerError as e:
                self.log.error("Server error while querying influx: %s", str(e), exc_info=True)
                time.sleep(1)
            except Exception as e:
                self.log.error("Error while querying influx: %s", str(e), exc_info=True)
                time.sleep(1) 
開發者ID:metabrainz,項目名稱:listenbrainz-server,代碼行數:15,代碼來源:influx_listenstore.py

示例15: demo_user_replay

# 需要導入模塊: from influxdb import exceptions [as 別名]
# 或者: from influxdb.exceptions import InfluxDBClientError [as 別名]
def demo_user_replay(user_name):
    replayer = DemoUserReplayer(user_name)
    try:
        replayer.start()
    except (InfluxDBClientError, InfluxDBServerError) as e:
        replayer.app.logger.error("Influx error while replaying listens: %s", str(e), exc_info=True)
        raise
    except Exception as e:
        replayer.app.logger.error("Error while replaying listens: %s", str(e), exc_info=True)
        raise 
開發者ID:metabrainz,項目名稱:listenbrainz-server,代碼行數:12,代碼來源:cli.py


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