有没有办法关闭执行器/测微计中返回的一些度量值?现在看看它们,我看到大约 1000 个,并希望将它们缩减到少数几个,比如 100 个,以便实际发送到我们的注册表。
3 回答
让我用几个例子来详细说明checketts发布的答案。您可以application.yml
像这样启用/禁用某些指标:
management:
metrics:
enable:
tomcat: true
jvm: false
process: false
hikaricp: false
system: false
jdbc: false
http: false
logback: true
或者在代码中定义一个 MeterFilter bean:
@Bean
public MeterFilter meterFilter() {
return new MeterFilter() {
@Override
public MeterFilterReply accept(Meter.Id id) {
if(id.getName().startsWith("tomcat.")) {
return MeterFilterReply.DENY;
}
if(id.getName().startsWith("jvm.")) {
return MeterFilterReply.DENY;
}
if(id.getName().startsWith("process.")) {
return MeterFilterReply.DENY;
}
if(id.getName().startsWith("system.")) {
return MeterFilterReply.DENY;
}
return MeterFilterReply.NEUTRAL;
}
};
}
Meter 过滤器可以通过 Micrometer slack 通道讨论的 3 种方式提供帮助:
- 禁用指标
- 组合尺寸
- 高基数封顶过滤器
Micrometer 内置了第一种类型的仪表过滤器。它还支持类似于日志记录工作方式的分层启用/禁用(就像如果有仪表一样my.request.total
,my.request.latency
您可以禁用所有以my.request
.
我已经实现了我自己的组合过滤器示例,如果您有一个具有高基数的指标并希望将它们组合到新的维度中,这将非常有用。例如,您有一个关于状态代码的维度,这使您可以将 200、201、203 响应代码组合为一个标签2xx
。这类似于 Netflix Spectator 的“占位符”支持。我很想在上游贡献该代码,但目前它是非常定制的,因此需要一些工作才能使其普遍可用。
捕获高基数维度的最后一种类型尚未创建,但将作为安全阀存在,确保如果指标可能具有大量标签值,它将计算唯一标签的数量,并且一旦达到最大值值被击中,禁用附加标签或将附加标签组合到一个公共存储桶中,这样该值就不会爆炸并可能压倒您的监控(如果按指标付费,则可能会花费您很多美元)