项目中看到了有埋点监控、报表、日志分析,有点兴趣想慢慢捣鼓一下
1. 数据埋点
监控机器环境的性能和业务流程或逻辑等各项数据,并根据这些数据生成对应的指标,那么我们就称为数据埋点。比如我们想知道某个接口调用的 TPS、机器 CPU 的使用率,这些都可以用到数据埋点
2. Micrometer
Micrometer 为流行的各种监控系统提供了一个简单的门面(类似于日志门面) —— 提供了与供应商无关的接口(counters,timers,gauges等),这些接口称为 meter 接口,其由 MeterRegistry 创建并保存,可理解为 MeterRegistry 这个集合里面存储了各种 meter 的度量数据,下面展示最简单的 counter 接口的使用
2.1 简单使用
其还有 timers、gauges 等接口,自行查阅
// 创建一个 meter 注册中心
MeterRegistry registry = new SimpleMeterRegistry();
// 创建一个名为 test 度量
Counter counter = meterRegistry.counter("test");
// 让这个度量的计数加 1
counter.increment();
就是如此简单,比如在调用指定接口的时候,可以使用 counter 接口来度量调用的次数,频率等等
2.2 命名规范
Micrometer 命名用 . 分隔小写单词字符,在接入其他监控系统时会自动将命名转成其适应的格式(或者可重写一个 NamingConvention 转换器来覆盖默认命名转换)。而且还支持多标签来量化,即有了多维度的度量,使统计更加丰富。下面简单的举例命名规范:
# 表示 http 请求
Counter counter = meterRegistry.counter("http.server.requests");
# 表示 http 请求中,请求 user 模块
Counter counter = meterRegistry.counter("http.server.requests", "user");
# 表示 http 请求中,请求 user 模块中,请求 login 登录方法
Counter counter = meterRegistry.counter("http.server.requests", "user", "login");
3. SpringBoot Actuator
SpringBoot Actuator 其底层使用了 Mircometer ,可度量 SpringBoot 应用和获取它的各项指标,可通过 HTTP 或 JMX 来调用 Actuator 暴露的各种端点,然后就可以获取一个正在运行中的应用的内部状态
当然内部指标并不是所有都可以向外暴露的,所以我们得有选择的开放,或者加入权限校验之后才能获取如下内容:
- 有那些可配置的属性
- 各依赖包的日志级别
- 占用了多少内存
- HTTP 埋点被请求了多少次
- 应用本身以及协作的外部服务的健康状态
- ......
3.1 添加依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
<version>2.4.3</version>
</dependency>