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


Python statsd.StatsClient方法代碼示例

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


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

示例1: __init__

# 需要導入模塊: import statsd [as 別名]
# 或者: from statsd import StatsClient [as 別名]
def __init__(self, env):
        self.env = env

        conf = env.config.get(ConfigKeys.STATS_SERVICE)
        host = conf.get(ConfigKeys.HOST)

        if env.config.get(ConfigKeys.TESTING, False) or host == 'mock':
            self.statsd = MockStatsd()
        else:
            import statsd

            port = conf.get(ConfigKeys.PORT)
            prefix = 'dino'
            if ConfigKeys.PREFIX in conf:
                prefix = conf.get(ConfigKeys.PREFIX)
            if ConfigKeys.INCLUDE_HOST_NAME in conf:
                include_host_name = conf.get(ConfigKeys.INCLUDE_HOST_NAME)
                if include_host_name is not None and str(include_host_name).strip().lower() in ['yes', '1', 'true']:
                    import socket
                    prefix = '%s.%s' % (prefix, socket.gethostname())

            self.statsd = statsd.StatsClient(host, int(port), prefix=prefix) 
開發者ID:thenetcircle,項目名稱:dino,代碼行數:24,代碼來源:statsd.py

示例2: disk

# 需要導入模塊: import statsd [as 別名]
# 或者: from statsd import StatsClient [as 別名]
def disk():
    c = statsd.StatsClient(STATSD_HOST, 8125, prefix=PREFIX + 'system.disk')
    while True:
        for path, label in PATHS:
            disk_usage = psutil.disk_usage(path)

            st = os.statvfs(path)
            total_inode = st.f_files
            free_inode = st.f_ffree
            inode_percentage = int(100*(float(total_inode - free_inode) / total_inode))

            c.gauge('%s.inodes.percent' % label, inode_percentage)
            c.gauge('%s.total' % label, disk_usage.total)
            c.gauge('%s.used' % label, disk_usage.used)
            c.gauge('%s.free' % label, disk_usage.free)
            c.gauge('%s.percent' % label, disk_usage.percent)
        time.sleep(GRANULARITY) 
開發者ID:thenetcircle,項目名稱:dino,代碼行數:19,代碼來源:statsd-agent.py

示例3: cpu_times_percent

# 需要導入模塊: import statsd [as 別名]
# 或者: from statsd import StatsClient [as 別名]
def cpu_times_percent():
    c = statsd.StatsClient(STATSD_HOST, 8125, prefix=PREFIX + 'system.cpu')
    while True:
        value = psutil.cpu_percent(interval=1)
        c.gauge('system_wide.percent', value)

        cpu_t_percent = psutil.cpu_times_percent(interval=1)
        c.gauge('system_wide.times_percent.user', cpu_t_percent.user)
        c.gauge('system_wide.times_percent.nice', cpu_t_percent.nice)
        c.gauge('system_wide.times_percent.system', cpu_t_percent.system)
        c.gauge('system_wide.times_percent.idle', cpu_t_percent.idle)
        c.gauge('system_wide.times_percent.iowait', cpu_t_percent.iowait)
        c.gauge('system_wide.times_percent.irq', cpu_t_percent.irq)
        c.gauge('system_wide.times_percent.softirq', cpu_t_percent.softirq)
        c.gauge('system_wide.times_percent.steal', cpu_t_percent.steal)
        c.gauge('system_wide.times_percent.guest', cpu_t_percent.guest)
        c.gauge('system_wide.times_percent.guest_nice', cpu_t_percent.guest_nice)
        time.sleep(GRANULARITY) 
開發者ID:thenetcircle,項目名稱:dino,代碼行數:20,代碼來源:statsd-agent.py

示例4: memory

# 需要導入模塊: import statsd [as 別名]
# 或者: from statsd import StatsClient [as 別名]
def memory():
    c = statsd.StatsClient(STATSD_HOST, 8125, prefix=PREFIX + 'system.memory')
    while True:
        swap = psutil.swap_memory()
        c.gauge('swap.total', swap.total)
        c.gauge('swap.used', swap.used)
        c.gauge('swap.free', swap.free)
        c.gauge('swap.percent', swap.percent)

        virtual = psutil.virtual_memory()
        c.gauge('virtual.total', virtual.total)
        c.gauge('virtual.available', virtual.available)
        c.gauge('virtual.used', virtual.used)
        c.gauge('virtual.free', virtual.free)
        c.gauge('virtual.percent', virtual.percent)
        c.gauge('virtual.active', virtual.active)
        c.gauge('virtual.inactive', virtual.inactive)
        c.gauge('virtual.buffers', virtual.buffers)
        c.gauge('virtual.cached', virtual.cached)
        time.sleep(GRANULARITY) 
開發者ID:thenetcircle,項目名稱:dino,代碼行數:22,代碼來源:statsd-agent.py

示例5: online_count

# 需要導入模塊: import statsd [as 別名]
# 或者: from statsd import StatsClient [as 別名]
def online_count():
    c = statsd.StatsClient(STATSD_HOST, 8125, prefix=PREFIX + 'online')
    while True:
        for _, _, community, db_num in hosts:
            count = r_servers[community].scard('users:multicast')
            c.gauge('%s.count' % community, count)

            sessions = r_servers[community].hgetall('session:count')
            session_count = 0

            for _, value in sessions.items():
                session_count += int(float(str(value, 'utf-8')))

            c.gauge('%s.count' % community, count)
            c.gauge('%s.sessions' % community, session_count)
        time.sleep(GRANULARITY) 
開發者ID:thenetcircle,項目名稱:dino,代碼行數:18,代碼來源:statsd-online-count.py

示例6: connect

# 需要導入模塊: import statsd [as 別名]
# 或者: from statsd import StatsClient [as 別名]
def connect(self, params):
        self.logger.info("Connect: Connecting..")

        host = params.get('host')
        port = params.get('port')
        prefix = params.get('prefix', None)
        protocol = params.get('protocol')

        self.host = host
        self.port = port
        self.protocol = protocol

        if protocol == 'TCP':
            timeout = params.get('tcp', None)['timeout']
            timeout = None if timeout == 0 else timeout
            self.instance = statsd.TCPStatsClient(host, port, prefix, timeout)
        elif protocol == 'UDP':
            maxudpsize = params.get('udp', 512)
            if maxudpsize is not None:
                maxudpsize = maxudpsize['maxudpsize']
            self.instance = statsd.StatsClient(host, port, prefix, maxudpsize) 
開發者ID:rapid7,項目名稱:insightconnect-plugins,代碼行數:23,代碼來源:connection.py

示例7: __init__

# 需要導入模塊: import statsd [as 別名]
# 或者: from statsd import StatsClient [as 別名]
def __init__(self, interface_dict):
		self.log = logging.getLogger('Main.Feeds.RPC')

		self.worker_pools   = {}
		self.interface_dict = interface_dict

		self.mon_con = statsd.StatsClient(
				host = settings_file.GRAPHITE_DB_IP,
				port = 8125,
				prefix = 'ReadableWebProxy.FetchAgent',
				)

		self.debug_interval = 10
		self.chunk_flush_interval = 10
		self.last_debug = time.time() - self.debug_interval
		self.last_chunk_flush = time.time() - self.chunk_flush_interval

		os.makedirs(settings_file.CHUNK_CACHE_DIR, exist_ok=True) 
開發者ID:fake-name,項目名稱:ReadableWebProxy,代碼行數:20,代碼來源:MessageProcessor.py

示例8: init

# 需要導入模塊: import statsd [as 別名]
# 或者: from statsd import StatsClient [as 別名]
def init():
    global _client

    statsd_host = os.environ.get('FLANKER_METRICS_HOST')
    statsd_port = os.environ.get('FLANKER_METRICS_PORT')
    statsd_prfx = os.environ.get('FLANKER_METRICS_PREFIX')

    if not statsd_host or not statsd_port or not statsd_prfx:
        return

    try:
        import statsd
    except ImportError:
        return

    _client = statsd.StatsClient(statsd_host, statsd_port, prefix=statsd_prfx) 
開發者ID:duo-labs,項目名稱:isthislegit,代碼行數:18,代碼來源:metrics.py

示例9: get_statsd_logger

# 需要導入模塊: import statsd [as 別名]
# 或者: from statsd import StatsClient [as 別名]
def get_statsd_logger(self):
        if conf.getboolean('scheduler', 'statsd_on'):
            from statsd import StatsClient

            if conf.has_option('scheduler', 'statsd_custom_client_path'):
                stats_class = conf.getimport('scheduler', 'statsd_custom_client_path')

                if not issubclass(stats_class, StatsClient):
                    raise AirflowConfigException(
                        "Your custom Statsd client must extend the statsd.StatsClient in order to ensure "
                        "backwards compatibility."
                    )
                else:
                    log.info("Successfully loaded custom Statsd client")

            else:
                stats_class = StatsClient

        statsd = stats_class(
            host=conf.get('scheduler', 'statsd_host'),
            port=conf.getint('scheduler', 'statsd_port'),
            prefix=conf.get('scheduler', 'statsd_prefix'))
        allow_list_validator = AllowListValidator(conf.get('scheduler', 'statsd_allow_list', fallback=None))
        return SafeStatsdLogger(statsd, allow_list_validator) 
開發者ID:apache,項目名稱:airflow,代碼行數:26,代碼來源:stats.py

示例10: __init__

# 需要導入模塊: import statsd [as 別名]
# 或者: from statsd import StatsClient [as 別名]
def __init__(self, config=None):
        # Shouldn't be trying imports in __init__.
        # It turns what should be a load error into a runtime error
        config = normalize_config(config)
        self.config = config
        self.client = InfluxDBClient(config['host'], config['port'], config['user'], config['passw'], config['db'], config['ssl'])
        self.schemas = [(re.compile(patt), step) for (patt, step) in config['schema']]
        try:
            self.statsd_client = statsd.StatsClient(config['statsd'].get('host'),
                                                    config['statsd'].get('port', 8125)) \
                                                    if 'statsd' in config and config['statsd'].get('host') else NullStatsd()
        except NameError:
            logger.warning("Statsd client configuration present but 'statsd' module"
                           "not installed - ignoring statsd configuration..")
            self.statsd_client = NullStatsd()
        self._setup_logger(config['log_level'], config['log_file'])
        self.es = None
        if config['es_enabled']:
            try:
                from elasticsearch import Elasticsearch
            except ImportError:
                logger.warning("Elasticsearch configuration present but 'elasticsearch'"
                               "module not installed - ignoring elasticsearch configuration..")
            else:
                self.es = Elasticsearch(config['es_hosts']) 
開發者ID:vimeo,項目名稱:graphite-influxdb,代碼行數:27,代碼來源:graphite_influxdb.py

示例11: _get_statsd_client

# 需要導入模塊: import statsd [as 別名]
# 或者: from statsd import StatsClient [as 別名]
def _get_statsd_client(*, prefix: str) -> StatsClient:
    """
    Object pool method that reuse already created StatsClient based on prefix
    :param prefix:
    :return:
    """
    if not has_app_context() or not current_app.config[config.IS_STATSD_ON]:
        return None
    else:
        if prefix not in __STATSD_POOL:
            with __STATSD_POOL_LOCK:
                if prefix not in __STATSD_POOL:
                    LOGGER.info('Instantiate StatsClient with prefix {}'.format(prefix))
                    statsd_client = StatsClient(prefix=prefix)
                    __STATSD_POOL[prefix] = statsd_client
                    return statsd_client

        if LOGGER.isEnabledFor(logging.DEBUG):
            LOGGER.debug('Reuse StatsClient with prefix {}'.format(prefix))
        return __STATSD_POOL[prefix] 
開發者ID:lyft,項目名稱:amundsenmetadatalibrary,代碼行數:22,代碼來源:statsd_utilities.py

示例12: test_get_statsd_client

# 需要導入模塊: import statsd [as 別名]
# 或者: from statsd import StatsClient [as 別名]
def test_get_statsd_client(self) -> None:
        with patch.object(current_app, 'config') as mock_config, \
                patch.object(StatsClient, '__init__', return_value=None) as mock_statsd_init:
            mock_config.return_value.single.return_value = True

            statsd_client1 = _get_statsd_client(prefix='foo')
            self.assertIsNotNone(statsd_client1)
            statsd_client2 = _get_statsd_client(prefix='foo')
            self.assertIsNotNone(statsd_client2)
            self.assertEqual(statsd_client1, statsd_client2)

            self.assertEqual(mock_statsd_init.call_count, 1)

            statsd_client3 = _get_statsd_client(prefix='bar')
            self.assertIsNotNone(statsd_client3)
            statsd_client4 = _get_statsd_client(prefix='bar')
            self.assertIsNotNone(statsd_client4)
            self.assertEqual(statsd_client3, statsd_client4)

            self.assertNotEqual(statsd_client1, statsd_client3)
            self.assertEqual(mock_statsd_init.call_count, 2) 
開發者ID:lyft,項目名稱:amundsenmetadatalibrary,代碼行數:23,代碼來源:test_statsd_utilities.py

示例13: get_statsd_client

# 需要導入模塊: import statsd [as 別名]
# 或者: from statsd import StatsClient [as 別名]
def get_statsd_client(self):
        if not statsd:
            return None
        statsd_args = {}
        if self._statsd_host:
            statsd_args['host'] = self._statsd_host
        if self._statsd_port:
            statsd_args['port'] = self._statsd_port
        if statsd_args:
            try:
                return statsd.StatsClient(**statsd_args)
            except Exception:
                self.log.warning('Cannot establish connection to statsd')
                return None
        else:
            return None 
開發者ID:openstack,項目名稱:openstacksdk,代碼行數:18,代碼來源:cloud_region.py

示例14: _get_statsd_client

# 需要導入模塊: import statsd [as 別名]
# 或者: from statsd import StatsClient [as 別名]
def _get_statsd_client(*, prefix: str) -> StatsClient:
    """
    Object pool method that reuse already created StatsClient based on prefix
    :param prefix:
    """
    if not current_app.config[config.STATS_FEATURE_KEY]:
        # return if stats feature is not enabled
        return None
    else:
        if prefix not in _STATSD_POOL:
            with _STATSD_POOL_LOCK:
                if prefix not in _STATSD_POOL:
                    LOGGER.info('Instantiate StatsClient with prefix {}'.format(prefix))
                    statsd_client = StatsClient(prefix=prefix)
                    _STATSD_POOL[prefix] = statsd_client
                    return statsd_client

        if LOGGER.isEnabledFor(logging.DEBUG):
            LOGGER.debug('Reuse StatsClient with prefix {}'.format(prefix))
        return _STATSD_POOL[prefix] 
開發者ID:lyft,項目名稱:amundsensearchlibrary,代碼行數:22,代碼來源:statsd_utilities.py

示例15: __init__

# 需要導入模塊: import statsd [as 別名]
# 或者: from statsd import StatsClient [as 別名]
def __init__(self,
                 conf,
                 task,
                 publisher=NoopPublisher()):
        # type: (ConfigTree, Task, Publisher) -> None
        self.task = task
        self.conf = conf
        self.publisher = publisher
        self.scoped_conf = Scoped.get_scoped_conf(self.conf,
                                                  self.get_scope())
        if self.scoped_conf.get_bool(DefaultJob.IS_STATSD_ENABLED, False):
            prefix = 'amundsen.databuilder.job.{}'.format(self.scoped_conf.get_string(DefaultJob.JOB_IDENTIFIER))
            LOGGER.info('Setting statsd for job metrics with prefix: {}'.format(prefix))
            self.statsd = StatsClient(prefix=prefix)
        else:
            self.statsd = None 
開發者ID:lyft,項目名稱:amundsendatabuilder,代碼行數:18,代碼來源:job.py


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