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


Python prometheus_client.Histogram方法代碼示例

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


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

示例1: histogram

# 需要導入模塊: import prometheus_client [as 別名]
# 或者: from prometheus_client import Histogram [as 別名]
def histogram(self, name, description, labels=None, **kwargs):
        """
        Use a Histogram to track the execution time and invocation count
        of the method.

        :param name: the name of the metric
        :param description: the description of the metric
        :param labels: a dictionary of `{labelname: callable_or_value}` for labels
        :param kwargs: additional keyword arguments for creating the Histogram
        """

        return self._track(
            Histogram,
            lambda metric, time: metric.observe(time),
            kwargs, name, description, labels,
            registry=self.registry
        ) 
開發者ID:rycus86,項目名稱:prometheus_flask_exporter,代碼行數:19,代碼來源:__init__.py

示例2: get_prometheus_histogram

# 需要導入模塊: import prometheus_client [as 別名]
# 或者: from prometheus_client import Histogram [as 別名]
def get_prometheus_histogram(self):
        registry = self.get_prometheus_registry()
        if not registry or not prometheus_client:
            return
        # We have to hide a reference to the histogram on the registry
        # object, because it's collectors must be singletons for a given
        # registry but register at creation time.
        hist = getattr(registry, '_openstacksdk_histogram', None)
        if not hist:
            hist = prometheus_client.Histogram(
                'openstack_http_response_time',
                'Time taken for an http response to an OpenStack service',
                labelnames=[
                    'method', 'endpoint', 'service_type', 'status_code'
                ],
                registry=registry,
            )
            registry._openstacksdk_histogram = hist
        return hist 
開發者ID:openstack,項目名稱:openstacksdk,代碼行數:21,代碼來源:cloud_region.py

示例3: __init__

# 需要導入模塊: import prometheus_client [as 別名]
# 或者: from prometheus_client import Histogram [as 別名]
def __init__(self,
                 name,
                 documentation,
                 labelnames=(),
                 namespace='',
                 subsystem='',
                 unit='',
                 registry=REGISTRY,
                 labelvalues=None,
                 buckets=DEFAULT_BUCKETS,
                 ):
        self._prepare_buckets(buckets)
        super(Histogram, self).__init__(
            name=name,
            documentation=documentation,
            labelnames=labelnames,
            namespace=namespace,
            subsystem=subsystem,
            unit=unit,
            registry=registry,
            labelvalues=labelvalues,
        )
        self._kwargs['buckets'] = buckets 
開發者ID:prometheus,項目名稱:client_python,代碼行數:25,代碼來源:metrics.py

示例4: __init__

# 需要導入模塊: import prometheus_client [as 別名]
# 或者: from prometheus_client import Histogram [as 別名]
def __init__(self,
        name,
        documentation,
        labelnames=(),
        namespace='',
        subsystem='',
        unit='',
        registry=REGISTRY,
        labelvalues=None,
        buckets=DEFAULT_BUCKETS,
    ):
        self._prepare_buckets(buckets)
        super(Histogram, self).__init__(
            name=name,
            documentation=documentation,
            labelnames=labelnames,
            namespace=namespace,
            subsystem=subsystem,
            unit=unit,
            registry=registry,
            labelvalues=labelvalues,
        )
        self._kwargs['buckets'] = buckets 
開發者ID:holzschu,項目名稱:Carnets,代碼行數:25,代碼來源:metrics.py

示例5: histogram_observe

# 需要導入模塊: import prometheus_client [as 別名]
# 或者: from prometheus_client import Histogram [as 別名]
def histogram_observe(name, observation, description="", buckets=None, **kwargs):
    global metrics, enabled

    if not enabled:
        return True

    try:
        if name not in metrics:
            if buckets:
                buckets.append(float("inf"))
                metrics[name] = Histogram(name, description, list(kwargs.keys()), buckets=buckets)
            else:
                metrics[name] = Histogram(name, description, list(kwargs.keys()))

        if kwargs:
            metrics[name].labels(**kwargs).observe(observation)
        else:
            metrics[name].observe(observation)
    except Exception as err:
        logger.warn("adding metric failed - exception: " + str(err))

    return True 
開發者ID:anchore,項目名稱:anchore-engine,代碼行數:24,代碼來源:metrics.py

示例6: init

# 需要導入模塊: import prometheus_client [as 別名]
# 或者: from prometheus_client import Histogram [as 別名]
def init(app, latency_buckets=None, multiprocess_mode='all',
         memcollect_enabled=True, metrics_list=None):
    app.metrics['RQS_COUNT'] = Counter(
        'sanic_request_count',
        'Sanic Request Count',
        ['method', 'endpoint', 'http_status']
    )

    hist_kwargs = {}
    if latency_buckets is not None:
        hist_kwargs = {'buckets': latency_buckets}
    app.metrics['RQS_LATENCY'] = Histogram(
        'sanic_request_latency_sec',
        'Sanic Request Latency Histogram',
        ['method', 'endpoint', 'http_status'],
        **hist_kwargs
    )

    if memcollect_enabled:
        app.metrics['PROC_RSS_MEM_BYTES'] = Gauge(
            'sanic_mem_rss_bytes',
            'Resident memory used by process running Sanic',
            multiprocess_mode=multiprocess_mode
        )
        app.metrics['PROC_RSS_MEM_PERC'] = Gauge(
            'sanic_mem_rss_perc',
            'A per cent of total physical memory used by ' +
            'the process running Sanic',
            multiprocess_mode=multiprocess_mode
        )

    if metrics_list:
        for name, pm_metric in metrics_list:
            app.metrics[name] = pm_metric 
開發者ID:dkruchinin,項目名稱:sanic-prometheus,代碼行數:36,代碼來源:metrics.py

示例7: set_histogram

# 需要導入模塊: import prometheus_client [as 別名]
# 或者: from prometheus_client import Histogram [as 別名]
def set_histogram(name, *args, **kwargs):
    metrics[name] = Histogram(name, *args, **kwargs)


#models.py metrics 
開發者ID:desec-io,項目名稱:desec-stack,代碼行數:7,代碼來源:metrics.py

示例8: __init__

# 需要導入模塊: import prometheus_client [as 別名]
# 或者: from prometheus_client import Histogram [as 別名]
def __init__(self, prefix, description, labels):
        """
        :param prefix: prefix to use for each metric name
        :param description: description of action to use in metric description
        :param labels: label names to define for each metric
        """
        self.full_prefix = '{}_{}'.format(self.__class__._PREFIX, prefix)
        self.progress = prometheus_client.Gauge(
            '{}_attempt_inprogress'.format(self.full_prefix),
            'In progress attempts to {}'.format(description),
            labels,
            registry=REGISTRY,
            multiprocess_mode='livesum')
        self.attempt_total = prometheus_client.Counter(
            '{}_attempt_total'.format(self.full_prefix),
            'Total attempts to {}'.format(description),
            labels,
            registry=REGISTRY)
        self.failure_total = prometheus_client.Counter(
            '{}_failure_total'.format(self.full_prefix),
            'Total failures to {}'.format(description),
            labels,
            registry=REGISTRY)
        self.duration = prometheus_client.Histogram(
            '{}_duration_seconds'.format(self.full_prefix),
            'Seconds to {}'.format(description),
            labels,
            registry=REGISTRY) 
開發者ID:airshipit,項目名稱:armada,代碼行數:30,代碼來源:metrics.py

示例9: __init__

# 需要導入模塊: import prometheus_client [as 別名]
# 或者: from prometheus_client import Histogram [as 別名]
def __init__(self, app, bento_service):
        self.app = app
        self.bento_service = bento_service

        from prometheus_client import Histogram, Counter, Gauge, CollectorRegistry

        service_name = self.bento_service.name
        namespace = config('instrument').get('default_namespace')
        # Use local registry instead of the global one to avoid duplicated metrics
        # register
        self.collector_registry = CollectorRegistry()

        self.metrics_request_duration = Histogram(
            name=service_name + '_request_duration_seconds',
            documentation=service_name + " API HTTP request duration in seconds",
            namespace=namespace,
            labelnames=['endpoint', 'service_version', 'http_response_code'],
            registry=self.collector_registry,
        )
        self.metrics_request_total = Counter(
            name=service_name + "_request_total",
            documentation='Totoal number of HTTP requests',
            namespace=namespace,
            labelnames=['endpoint', 'service_version', 'http_response_code'],
            registry=self.collector_registry,
        )
        self.metrics_request_in_progress = Gauge(
            name=service_name + "_request_in_progress",
            documentation='Totoal number of HTTP requests in progress now',
            namespace=namespace,
            labelnames=['endpoint', 'service_version'],
            registry=self.collector_registry,
        ) 
開發者ID:bentoml,項目名稱:BentoML,代碼行數:35,代碼來源:instruments.py

示例10: test_prometheus_histogram

# 需要導入模塊: import prometheus_client [as 別名]
# 或者: from prometheus_client import Histogram [as 別名]
def test_prometheus_histogram():
    @solid(required_resource_keys={'prometheus'})
    def prometheus_solid(context):
        h = Histogram(
            'pipeline_runtime_seconds',
            'Description of histogram',
            registry=context.resources.prometheus.registry,
        )
        h.observe(4.7)
        recorded = context.resources.prometheus.registry.get_sample_value(
            'pipeline_runtime_seconds_sum'
        )
        assert abs(4.7 - recorded) < EPS

    assert execute_solid(prometheus_solid, run_config=ENV, mode_def=MODE).success 
開發者ID:dagster-io,項目名稱:dagster,代碼行數:17,代碼來源:test_resources.py

示例11: get_histogram_buckets_from_evn

# 需要導入模塊: import prometheus_client [as 別名]
# 或者: from prometheus_client import Histogram [as 別名]
def get_histogram_buckets_from_evn(env_name):
    if env_name in os.environ:
        buckets = decode_buckets(os.environ.get(env_name))
    else:
        if hasattr(prometheus_client.Histogram, 'DEFAULT_BUCKETS'): # pragma: no cover
            buckets = prometheus_client.Histogram.DEFAULT_BUCKETS
        else: # pragma: no cover
            # For prometheus-client < 0.3.0 we cannot easily access
            # the default buckets:
            buckets = (.005, .01, .025, .05, .075, .1, .25, .5, .75, 1.0, 2.5, 5.0, 7.5, 10.0, float('inf'))
    return buckets 
開發者ID:zerok,項目名稱:celery-prometheus-exporter,代碼行數:13,代碼來源:celery_prometheus_exporter.py

示例12: _histogram

# 需要導入模塊: import prometheus_client [as 別名]
# 或者: from prometheus_client import Histogram [as 別名]
def _histogram(self, var, var_help, labels, buckets):
        return Histogram(var, var_help, labels, buckets=buckets, registry=self._reg) # pylint: disable=unexpected-keyword-arg 
開發者ID:faucetsdn,項目名稱:faucet,代碼行數:4,代碼來源:faucet_metrics.py

示例13: __init__

# 需要導入模塊: import prometheus_client [as 別名]
# 或者: from prometheus_client import Histogram [as 別名]
def __init__(self):
        super(ProtonPrometheus, self).__init__()
        self.registry = CollectorRegistry()
        self.requests = Counter(
            'http_total_request',
            'Counter of total HTTP requests',
            ['method', 'path', 'status'],
            registry=self.registry)

        self.request_historygram = Histogram(
            'request_latency_seconds',
            'Histogram of request latency',
            ['method', 'path', 'status'],
            registry=self.registry) 
開發者ID:PruthviKumarBK,項目名稱:PROTON,代碼行數:16,代碼來源:proton_prometheus.py

示例14: setup_metrics

# 需要導入模塊: import prometheus_client [as 別名]
# 或者: from prometheus_client import Histogram [as 別名]
def setup_metrics(app, app_name):
    app['REQUEST_COUNT'] = Counter(
      'requests_total', 'Total Request Count',
      ['app_name', 'method', 'endpoint', 'http_status']
    )
    app['REQUEST_LATENCY'] = Histogram(
        'request_latency_seconds', 'Request latency',
        ['app_name', 'endpoint']
    )

    app['REQUEST_IN_PROGRESS'] = Gauge(
        'requests_in_progress_total', 'Requests in progress',
        ['app_name', 'endpoint', 'method']
    )

    app.middlewares.insert(0, prom_middleware(app_name))
    app.router.add_get("/metrics", metrics) 
開發者ID:amitsaha,項目名稱:python-prometheus-demo,代碼行數:19,代碼來源:middleware.py


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