Springboot2关于Metrics

Metrics

  Spring Boot Actuator为Micrometer提供了依赖项管理和自动配置,Micrometer是一种支持大量监视系统的应用程序指标展示,包括:AppOptics、Atlas、Datadog、Dynatrace、Elastic、Ganglia、Graphite、Humio、Influx、JMX、KairosDB、New Relic、Prometheus、SignalFx、Simple (in-memory)、StatsD、Wavefront。

要了解有关Micrometer功能的更多信息,请参阅其参考文档,特别是概念部分。

1 入门

  Spring Boot自动配置组合MeterRegistry,并为其在类路径上找到的每个支持的实现向组合添加注册表。在micrometer-registry-{system}运行时类路径中具有依赖项足以让Spring Boot配置注册表。

  大多数注册表具有共同的特征。例如,即使Micrometer注册表实现位于类路径中,您也可以禁用特定的注册表。例如,禁用Datadog:

management.metrics.export.datadog.enabled=false

  Spring Boot还会将任何自动配置的注册表添加到Metrics该类的全局静态复合注册表中,除非您明确告诉它不要:

management.metrics.use-global-registry=false

  您可以注册任意数量的MeterRegistryCustomizerbean来进一步配置注册表,例如在向注册表注册任何计量器(meter)之前应用通用标签:

@Bean

MeterRegistryCustomizer<MeterRegistry> metricsCommonTags() {

return registry -> registry.config().commonTags("region", "us-east-1");

}

  您可以通过更具体地了解通用类型,将自定义项应用于特定的注册表实现:

@Bean

MeterRegistryCustomizer<GraphiteMeterRegistry> graphiteMetricsNamingConvention() {

return registry -> registry.config().namingConvention(MY_CUSTOM_CONVENTION);

}

  完成该设置后,您可以注入MeterRegistry组件并注册指标:

@Component

public class SampleBean {

    private final Counter counter;

    public SampleBean(MeterRegistry registry) {

        this.counter = registry.counter("received.messages");

}

public void handleMessage(String message) {

    this.counter.increment();

    // handle message implementation

}

}

Spring Boot还配置了内置工具(即MeterBinder实现),您可以通过配置或专用注释标记来控制它们。

2 支持的监控系统–Prometheus

  Prometheus希望抓取或轮询单个应用程序实例以获取指标。Spring Boot提供了一个可用的执行器端点/actuator/prometheus以适当的格式显示Prometheus抓取。

端点默认情况下不可用,必须公开,有关更多详细信息,请参见暴露端点

  这是scrape_config要添加到的示例prometheus.yml:

scrape_configs:

  - job_name: 'spring'

    metrics_path: '/actuator/prometheus'

    static_configs:

  - targets: ['HOST:PORT']

  对于短暂的或批处理的工作,其时间可能不够长,无法被抓取,可以使用Prometheus Pushgateway支持将其指标暴露给Prometheus。要启用Prometheus Pushgateway支持,请在项目中添加以下依赖项:

<dependency>

    <groupId>io.prometheus</groupId>

    <artifactId>simpleclient_pushgateway</artifactId>

</dependency>

  当在类路径中存在Prometheus Pushgateway依赖项时,Spring Boot会自动配置PrometheusPushGatewayManager组件。这可以管理将指标推送到Prometheus Pushgateway。PrometheusPushGatewayManager可以在使用属性management.metrics.export.prometheus.pushgateway配置。对于高级配置,您还可以提供自己的PrometheusPushGatewayManager组件。

3 支持的指标

  如果适用,Spring Boot将注册以下核心指标:

JVM指标,报告以下各项的利用率:

    各种内存和缓冲池

    与垃圾收集有关的统计数据

    线程利用率

    加载/卸载的类数

CPU指标

文件描述符指标

卡夫卡消耗指标

Log4j2指标:记录每个级别记录到Log4j2的事件数

Logback指标:记录每个级别记录到Logback的事件数

正常运行时间指标:报告正常运行时间的量度和代表应用程序绝对启动时间的固定量度

Tomcat指标(server.tomcat.mbeanregistry.enabled必须设置true为才能注册所有Tomcat指标)

Spring集成指标

Spring MVC指标

  通过自动配置,可以检测由Spring MVC处理的请求。当management.metrics.web.server.request.autotime.enabled为true时,将对所有请求进行这种检测。或者,当设置为false时,可以通过添加@Timed到请求处理方法来启用检测:

@RestController

@Timed

public class MyController {

    @GetMapping("/api/people")

    @Timed(extraTags = { "region", "us-east-1" })

    @Timed(value = "all.people", longTask = true)

    public List<Person> listPeople() { ... }

}

  1.控制器类,用于对控制器中的每个请求处理程序启用计时。

  2.一种启用单个端点的方法。如果您将它放在类中,则不必这样做,但是可以用于进一步为此特定端点自定义timer计时器。

  3.一种longTask = true用于为该方法启用长任务计时器的方法。长任务计时器需要一个单独的度量metric名称,并且可以与短任务计时器堆叠在一起。

  默认情况下,指标名称为http.server.requests。可以通过设置management.metrics.web.server.request.metric-name属性来自定义名称。

  默认情况下,与Spring MVC相关的指标带有以下信息标记:

标签描述

exception处理请求时引发的任何异常的简单类名。

method请求的方法(例如GET或POST)

outcome基于响应状态码的请求结果。1xx是INFORMATIONAL,2xx是SUCCESS,3xx是REDIRECTION,4xx CLIENT_ERROR和5xx是SERVER_ERROR

status响应的HTTP状态代码(例如200或500)

uri变量替换之前的请求URI模板(如果可能)(例如,/api/person/{id})

  要自定义标签,请提供@Bean实现的WebMvcTagsProvider。

HTTP客户端指标

  启动器同时管理仪表RestTemplate和WebClient。为此,您必须注入自动配置的构建器并使用它来创建实例:

RestTemplateBuilder 对于 RestTemplate

WebClient.Builder 对于 WebClient

  也可以手动应用负责此工具的定制程序,即MetricsRestTemplateCustomizer和MetricsWebClientCustomizer。

  默认情况下,指标名称为http.client.requests。可以通过设置management.metrics.web.client.request.metric-name属性来自定义名称。

  默认情况下,通过检测的客户端生成的指标会标记以下信息:

标签描述

clientNameURI的主机部分

method请求的方法(例如GET或POST)

outcome基于响应状态码的请求结果。1xx是INFORMATIONAL,2xx是SUCCESS,3xx是REDIRECTION,4xx CLIENT_ERROR和5xx是SERVER_ERROR,否则UNKNOWN

status响应的HTTP状态代码(例如200或500)(IO_ERROR如果存在I / O问题),否则CLIENT_ERROR

uri变量替换之前的请求URI模板(如果可能)(例如,/api/person/{id})

  要自定义标签,并根据您选择的客户端,可以提供@Bean实现RestTemplateExchangeTagsProvider或WebClientExchangeTagsProvider。RestTemplateExchangeTags和WebClientExchangeTags中有方便的静态函数。

缓存指标

  通过自动配置可以在启动时使用前缀为Cache的指标来检测所有可用的cache。对于解百纳的cache信息是进行了标准化设置的。此外定制的cache指标也是可用的。

  支持以下缓存库:

Caffeine

EhCache 2

Hazelcast

Any compliant JCache (JSR-107) 的实现

  指标由cache的名称以及CacheManager从Bean名称派生的的名称标记(添加tag)。

  只有启动时可用的缓存才绑定到注册表。对于在启动阶段后即时或以编程方式创建的缓存,需要显式注册。可以使用CacheMetricsRegistrarBean来简化该过程。

数据源指标

  自动配置可使前缀为jdbc.connections的metric指标的所有DataSource对象可视化。数据源检测产生的gauge表示池中当前活动,空闲,最大允许和最小允许的连接。

  metrics还通过DataSource基于bean名称的计算名称来标记(添加tag)。

  默认情况下,Spring Boot为所有支持的数据源提供元数据。如果您喜欢的数据源不支持开箱即用,则可以添加其他DataSourcePoolMetadataProvider组件。请参阅DataSourcePoolMetadataProvidersConfiguration示例。

  此外,Hikari特定指标带有hikaricp前缀。每个度量标准都以“池”的名称标记(可以通过来控制spring.datasource.name)。

4 注册自定义指标

  要注册自定义指标,请插入MeterRegistry到您的组件中,如以下示例所示:

class Dictionary {

    private final List<String> words = new CopyOnWriteArrayList<>();

    Dictionary(MeterRegistry registry) {

        registry.gaugeCollectionSize("dictionary.size", Tags.empty(), this.words);

    }

    // …

}

  如果发现您反复在组件或应用程序中检测一组metrics,则可以将此组metrics封装在MeterBinder实现中。默认情况下,所有MeterBinderbean的metrics都将自动绑定到Spring-managed MeterRegistry。

5 自定义单个指标

  如果需要将自定义应用于特定Meter实例,则可以使用该io.micrometer.core.instrument.config.MeterFilter接口。默认情况下,所有MeterFilter组件都会自动应用于MicroMeter的MeterRegistry.Config。

  例如,如果要将所有仪表ID中以com.example开头的mytag.region标签重命名为mytag.area,则可以执行以下操作:

@Bean

public MeterFilter renameRegionTagMeterFilter() {

return MeterFilter.renameTag("com.example", "mytag.region", "mytag.area");

}

通用标签

  通用标签通常用于在操作环境,如主机,实例,区域,堆栈等,进行维度深入分析。通用标签适用于所有仪表,并可以按以下示例所示进行配置:

management.metrics.tags.region=us-east-1

management.metrics.tags.stack=prod

  上面的示例将us-east-1和prod分别添加到region和stack到所有仪表。

如果使用Graphite,则常用标签的顺序很重要。由于使用这种方法不能保证通用标签的顺序,因此建议Graphite用户定义一个自定义MeterFilter。

Per-meter属性

Per-meter适用于以给定名称开头的所有meter ID。例如,以下将禁用所有ID以example.remote开头的meter。

management.metrics.enable.example.remote=false

  以下属性允许per-meter自定义:

表8.per-meter自定义

属性描述

management.metrics.enable是否拒绝仪表发出任何指标

management.metrics.distribution.percentiles-histogram是否发布适合于计算可凝集(跨维度)百分位数逼近的直方图

management.metrics.distribution.minimum-expected-value,management.metrics.distribution.maximum-expected-value通过限制期望值的范围来发布较少的直方图bucket

management.metrics.distribution.percentiles发布在应用程序中计算的百分位值

management.metrics.distribution.sla发布包含您的SLA定义的存储桶的累积直方图

有关percentiles-histogram,percentiles并sla概念更多的细节,请参阅“Histogram and percentiles”部分文档。

6 指标端点

Spring Boot提供了一个metrics端点,可用于诊断检查应用程序收集的指标。端点默认情况下不可用,必须公开,有关更多详细信息,请参见暴露端点

  路径 /actuator/metrics 展示可用meter名称的列表。您可以通过提供特定的meter名称作为选择器来向下浏览以查看有关该仪表的信息,例如:/actuator/metrics/jvm.memory.max。

  您在此处使用的名称应与代码中使用的名称相匹配,而不是已经针对监视系统进行了命名约定标准化后的名称。

  您还可以tag=KEY:VALUE在URL的末尾添加任意数量的查询参数,以在维度上进一步细分meter,例如/actuator/metrics/jvm.memory.max?tag=area:nonheap。

  报告的测量值是与仪表名称和已应用的任何标签相匹配的所有仪表的统计信息的总和。因此,在上面的示例中,返回的“值”统计量是堆的“代码缓存”,“压缩类空间”和“元空间”区域的最大内存占用量的总和。如果您只想查看“ Metaspace”的最大大小,则可以添加一个额外的tag=id:Metaspace,即/actuator/metrics/jvm.memory.max?tag=area:nonheap&tag=id:Metaspace。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,001评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,210评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,874评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,001评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,022评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,005评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,929评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,742评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,193评论 1 309
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,427评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,583评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,305评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,911评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,564评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,731评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,581评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,478评论 2 352

推荐阅读更多精彩内容