TOC
前言
上周有个网友问 springboot 程序的 metrics 越来越多了,有40W的指标,现在想清除一些没用的 metrics,要怎样做呢?!
当时我看到这个问题觉得挺有意思,因为我的线上程序也有动态 metrics,只不过指标没有达到那么大的量,所以我研究了一下这个问题可以怎么样处理.
用什么添加做的动态metrics就先看支不支持删除
动态创建 metrics 是直接用的io.micrometer.core.instrument.MeterRegistry
对象,例如:registry.gauge(name,tags,valueObject)
.就可以将一个 name 的 gauge 类型的 metrics 添加到 registry 里面了,收集 metrics 时就可以看到这个新增的 metrics 了.
于是看看这个对象还有什么删除相关的方法:
首先尝试的时delete
方法,发现没有类似的方法:
然后试试remove
,可以发现有两个remove
方法可以用,分别传入ID对象
和metrics对象
,但如果需要全部清理呢?有没有类似 List 的clear
方法呢?
再试试clear
方法,发现是有这个方法的,并且我先测试了一遍,看看clear
方法是否能够达到预期(清除metrics).
实操测试
于是我一顿操作:
- 写一个 API 接口,接口内容是执行
meterRegistry.clear();
- 启动 springboot 程序
- 浏览器看看
/actuator/prometheus
接口返回的内容 - 调用清理 metrics 的接口,也就是第一步写的接口
- 再次浏览器看看
/actuator/prometheus
接口返回的内容
清理 metrics 前的接口内容:
清理了 metrics 后的接口内容:
可以看到调用接口后 metrics 清除了信息.
方法有效✔, 可以给网友回复了.
网友实操不行
网友说没这个方法? 咋回事?!
点进clear
源码看了一下,方法说明描述得很清楚,1.2.0 版本发布的方法,而网友用的版本低于 1.2.0,因此没有这个方法.
/**
* Clear all meters.
* @since 1.2.0
*/
@Incubating(since = "1.2.0")
public void clear() {
meterMap.keySet().forEach(this::remove);
}
能不能根据根据某些标签来删除特定的metrics
当然可以!
可以看到每一个 metrics 的 tag 列表都可以拿得到,那就好办了,通过标签对比筛选出自己想要删除的 metrics,然后用remove
方法删除就可以了.
总结
当程序有动态新增 metrics 时就要考虑无用 metrics 清除的机制,如果 metrics 数量太多的话就会影响到业务应用.
微信公众号
扫描下面的二维码关注我们的微信公众号,第一时间查看最新内容。同时也可以关注我的Github,看看我都在了解什么技术,在页面底部可以找到我的Github。