项目中看到了有埋点监控、报表、日志分析,有点兴趣想慢慢捣鼓一下
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>
3.2 基
小型项目必备:SpringBoot Actuator—埋点和监控
最新推荐文章于 2024-07-19 10:32:51 发布
本文介绍了如何使用SpringBoot Actuator和Micrometer进行数据埋点和监控。通过添加依赖、配置,展示了Actuator的健康指标、信息端点、指标端点的使用,以及SpringBoot Admin如何作为监控UI,简化了手动配置的过程。文章还讨论了其在小型项目中的适用性和扩展至Prometheus等时序数据库的必要性。
摘要由CSDN通过智能技术生成