概述
Spring Boot 监控核心是 spring-boot-starter-actuator 依赖,增加依赖后, Spring Boot 会默认配置一些通用的监控,比如 jvm 监控、类加载、健康监控等。
利用SpringBoot作为微服务单元的实例化技术选型时,我们不可避免的要面对的一个问题就是如何实时监控应用的运行状况数据,比如:健康度、运行指标、日志信息、线程状况等等。本文就该问题做一点探索并记录试验过程。
- 入门使用:Actuator插件
Actuator插件是SpringBoot原生提供的一个服务,可以通过暴露端点路由,用来输出应用中的诸多 端点信息。实战一下!
pom.xml中添加依赖:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
启动Spring Boot应用程序之后,只要在浏览器中输入端点信息就能获得应用的一些状态信息。
常用端点列举如下,可以一个个详细试一下:
/info 应用基本信息
/health 健康度信息
/metrics 运行指标
/env 环境变量信息
/loggers 日志相关
/dump 线程相关信息
/trace 请求调用轨迹
当然此时只能使用/health 和 /info端点,其他因为权限问题无法访问。想访问指定端点的话可以在yml配置中添加相关的配置项,比如/metrics端点则需要配置:
endpoints:
metrics:
sensitive: false
此时浏览器访问/metrics端点就能得到诸如下面所示的信息:
{
"mem": 71529,
"mem.free": 15073,
"processors": 4,
"instance.uptime": 6376,
"uptime": 9447,
"systemload.average": -1.0,
"heap.committed": 48024,
"heap.init": 16384,
"heap.used": 32950,
"heap": 506816,
"nonheap.committed": 23840,
"nonheap.init": 160,
"nonheap.used": 23506,
"nonheap": 0,
"threads.peak": 25,
"threads.daemon": 23,
"threads.totalStarted": 28,
"threads": 25,
"classes": 6129,
"classes.loaded": 6129,
"classes.unloaded": 0,
"gc.copy.count": 74,
"gc.copy.time": 173,
"gc.marksweepcompact.count": 3,
"gc.marksweepcompact.time": 88,
"httpsessions.max": -1,
"httpsessions.active": 0
}
当然也可以开启全部端点权限,只需如下配置即可:
endpoints:
sensitive: false
由于Actuator插件提供的监控能力毕竟有限,而且UI比较简陋,因此需要一个更加成熟一点的工具。
Spring Boot Admin监控系统
- 什么是Spring Boot Admin
Spring Boot Admin 是一个管理和监控Spring Boot 应用程序的开源软件。每个应用都认为是一个客户端,通过HTTP或者使用 Eureka注册到admin server中进行展示,Spring Boot Admin UI部分使用AngularJs将数据展示在前端。
Spring Boot Admin 是一个针对spring-boot的actuator接口进行UI美化封装的监控工具。他可以:在列表中浏览所有被监控spring-boot项目的基本信息,详细的Health信息、内存信息、JVM信息、垃圾回收信息、各种配置信息(比如数据源、缓存列表和命中率)等,还可以直接修改logger的level。
这篇文章给大家介绍如何使用Spring Boot Admin对Spring Boot应用进行监控。
1、监控单体应用
这节给大家展示如何使用Spring Boot Admin监控单个Spring Boot应用。
- Admin Server端
新建一个module子项目
添加pom依赖
<dependencies>
<dependency>
<groupId>de.codecentric</groupId>
<artifactId>spring-boot-admin-server</artifactId>
<version>1.5.6</version>
</dependency>
<dependency>
<groupId>de.codecentric</groupId>
<artifactId>spring-boot-admin-server-ui</artifactId>
<version>1.5.6</version>
</dependency>
</dependencies>
配置文件
server.port=8000
启动类
@Configuration
@EnableAutoConfiguration
@EnableAdminServer
public class AdminServerApplication {
public static void main(String[] args) {
SpringApplication.run(AdminServerApplication.class, args);
}
}
完成上面三步之后,启动服务端,浏览器访问http://localhost:8000
可以看到以下界面:
- Admin Client端
添加pom依赖
<dependencies>
<dependency>
<groupId>de.codecentric</groupId>
<artifactId>spring-boot-admin-starter-client</artifactId>
<version>1.5.6</version>
</dependency>
</dependencies>
添加配置文件
server.port=8001
spring.boot.admin.url=http://localhost:8000
management.security.enabled=false
-spring.boot.admin.url 配置Admin Server的地址
-management.security.enabled=false 关闭安全验证
启动类
@SpringBootApplicatio
public class AdminClientApplication {
public static void main(String[] args) {
SpringApplication.run(AdminClientApplication.class, args);
}
}
配置完成之后,启动Client端服务,再次访问服务:http://localhost:8000
可以看到客户端的相关信息。
首页会展示被监控的各个服务,点击详情可以查看某个服务的具体监控信息
![bb18c7d756adfc436b125f636f420c76.png](https://i-blog.csdnimg.cn/blog_migrate/eb30280220e6d12234bc98969aa1f6eb.jpeg)
通过上图可以看出,Spring Boot Admin以图形化的形式展示了应用的各项信息,这些信息大多都来自于Spring Boot Actuator提供的接口。
2、监控微服务
如果我们使用的是单个Spring Boot应用,就需要在每一个被监控的应用中配置Admin Server的地址信息;如果应用都注册在Eureka中(Consul也一样)就不需要再对每个应用进行配置,Spring Boot Admin会自动从注册中心抓取应用的相关信息。
这里使用四个示例项目来演示:
spring-boot-admin-server Admin Server端
spring-cloud-eureka 注册中心
spring-cloud-producer 应用一,Admin Client端
spring-cloud-producer-2 应用二,Admin Client端
Server端
示例项目:spring-boot-admin-server
项目依赖
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-eureka</artifactId>
</dependency>
<dependency>
<groupId>de.codecentric</groupId>
<artifactId>spring-boot-admin-server</artifactId>
<version>1.5.6</version>
</dependency>
<dependency>
<groupId>de.codecentric</groupId>
<artifactId>spring-boot-admin-server-ui</artifactId>
<version>1.5.6</version>
</dependency>
</dependencies>
增加了对eureka的支持
启动类
@Configuration
@EnableAutoConfiguration
@EnableDiscoveryClien
@EnableAdminServer
public class AdminServerApplication {
public static void main(String[] args) {
SpringApplication.run(AdminServerApplication.class, args);
}
}
上述步骤完成之后,启动Server端。
3、邮件告警
SpringBoot Admin将微服务中所有应用信息在后台进行了展示,非常方便我们对微服务整体的监控和治理,但是我们的运营人员也不可能一天24小时盯着监控后台,因此如果服务有异常时,有对应的邮件告警就太好了,其实SpringBoot Admin也给出了支持。
我们对上面的示例项目spring-boot-admin-server进行改造。
添加依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-mail</artifactId>
</dependency>
添加了邮件发送的starter包
配置文件
spring:
mail:
host: smtp.qq.com
username: xxxxx@qq.com
password: xxxx
properties:
mail:
smtp:
auth: true
starttls:
enable: true
required: true
boot:
admin:
notify:
mail:
from: xxxx@qq.com
to: xxxx@qq.com
在配置文件中添加邮件发送相关信息:邮件的发送者,接收者,协议,移动授权码等。关于spring boot邮件发送,可以参考
springboot邮件发送示例www.ityouknow.com配置完成后,重启spring-boot-admin-server,这样Admin Server就具备了邮件告警功能,默认情况下Admin Server对Eureka中的服务上下线都进行了监控,当服务上下线时,我们会收到如下邮件:
![d260ea73bccff2c97b01eabe222e880e.png](https://i-blog.csdnimg.cn/blog_migrate/ef9e36e0d9d5fb9892b7c66e38763e3f.jpeg)
当然这只是最基本的邮件监控,在实际的使用过程中,需要根据我们的情况对邮件告警内容进行自定义,比如监控堆内存的使用情况,当到达一定比例的时候进行告警等