查看: 809|回复: 0

[手机开发] Spring Boot应用监控实战

发表于 2018-5-9 08:00:03

Profile


概述

之前讲过Docker容器的可视化监控,即监控容器的运行情况,包括 CPU使用率、内存占用、网络状况以及磁盘空间等等一系列信息。同样利用SpringBoot作为微服务单元的实例化技术选型时,我们不可避免的要面对的一个问题就是如何实时监控应用的运行状况数据,比如:健康度、运行指标、日志信息、线程状况等等。本文就该问题做一点探索并记录试验过程。


入门使用:Actuator插件

Actuator插件是SpringBoot原生提供的一个服务,可以通过暴露端点路由,用来输出应用中的诸多 端点信息。实战一下!

pom.xml中添加依赖:
  1. <dependency>
  2. <groupId>org.springframework.boot</groupId>
  3. <artifactId>spring-boot-starter-actuator</artifactId>
  4. </dependency>
复制代码

启动Spring Boot应用程序之后,只要在浏览器中输入端点信息就能获得应用的一些状态信息。

常用端点列举如下,可以一个个详细试一下:

/info        应用基本信息 /health       健康度信息 /metrics      运行指标 /env        环境变量信息 /loggers      日志相关 /dump       线程相关信息 /trace       请求调用轨迹

当然此时只能使用/health/info端点,其他因为权限问题无法访问。想访问指定端点的话可以在yml配置中添加相关的配置项,比如/metrics端点则需要配置:

  1. endpoints:
  2. metrics:
  3. sensitive: false
复制代码

此时浏览器访问/metrics端点就能得到诸如下面所示的信息:

  1. {
  2. "mem": 71529,
  3. "mem.free": 15073,
  4. "processors": 4,
  5. "instance.uptime": 6376,
  6. "uptime": 9447,
  7. "systemload.average": -1.0,
  8. "heap.committed": 48024,
  9. "heap.init": 16384,
  10. "heap.used": 32950,
  11. "heap": 506816,
  12. "nonheap.committed": 23840,
  13. "nonheap.init": 160,
  14. "nonheap.used": 23506,
  15. "nonheap": 0,
  16. "threads.peak": 25,
  17. "threads.daemon": 23,
  18. "threads.totalStarted": 28,
  19. "threads": 25,
  20. "classes": 6129,
  21. "classes.loaded": 6129,
  22. "classes.unloaded": 0,
  23. "gc.copy.count": 74,
  24. "gc.copy.time": 173,
  25. "gc.marksweepcompact.count": 3,
  26. "gc.marksweepcompact.time": 88,
  27. "httpsessions.max": -1,
  28. "httpsessions.active": 0
  29. }
复制代码

当然也可以开启全部端点权限,只需如下配置即可:

  1. endpoints:
  2. sensitive: false
复制代码

由于Actuator插件提供的监控能力毕竟有限,而且UI比较简陋,因此需要一个更加成熟一点的工具


Spring Boot Admin监控系统

SBA则是基于Actuator更加进化了一步,其是一个针对Actuator接口进行UI美化封装的监控工具。我们来实验一下。

首先来创建一个Spring Boot Admin Server工程作为服务端

pom.xml中加入如下依赖:

  1. <dependency>
  2. <groupId>de.codecentric</groupId>
  3. <artifactId>spring-boot-admin-server</artifactId>
  4. <version>1.5.7</version>
  5. </dependency>
  6. <dependency>
  7. <groupId>de.codecentric</groupId>
  8. <artifactId>spring-boot-admin-server-ui</artifactId>
  9. <version>1.5.7</version>
  10. </dependency>
复制代码

然后在应用主类上通过加注解来启用Spring Boot Admin

  1. @EnableAdminServer
  2. @SpringBootApplication
  3. public class SpringbtAdminServerApplication {
  4. public static void main(String[] args) {
  5. SpringApplication.run(SpringbtAdminServerApplication.class, args);
  6. }
  7. }
复制代码

启动程序,浏览器打开 localhost:8081 查看Spring Boot Admin主页面:

Spring Boot Admin主页面

此时Application一栏空空如也,等待待监控的应用加入

创建要监控的Spring Boot应用

pom.xml中加入以下依赖

  1. <dependency>
  2. <groupId>de.codecentric</groupId>
  3. <artifactId>spring-boot-admin-starter-client</artifactId>
  4. <version>1.5.7</version>
  5. </dependency>
复制代码

然后在yml配置中添加如下配置,将应用注册到Admin服务端去:

  1. spring:
  2. boot:
  3. admin:
  4. url: http://localhost:8081
  5. client:
  6. name: AdminTest
复制代码

Client应用一启动,Admin服务立马推送来了消息,告诉你AdminTest上线了:

应用上线推送消息

此时去Admin主界面上查看,发现Client应用确实已经注册上来了:

Client应用已注册上来

查看Detail

Detail信息

查看 Metrics

Metrics信息

查看 Enviroment

Enviroment信息

查看JMX

JMX信息

查看Threads

Threads信息

查看Trace与详情

Trace信息

点击最上方JOURNAL,会看到被监控应用程序的事件变化:

应用程序的事件变化信息

图中可以清晰地看到,应用从 REGISTRATION UNKNOWN UP 的状态跳转。

这样就将Actuator插件提供的所有端点信息在SBA中全部尝试了一遍。


参考文献 http://codecentric.github.io/spring-boot-admin/1.5.7/
后记

作者更多的原创文章:在慕课网

作者一些其他容器化应用方面的文章:

利用K8S技术栈打造个人私有云连载文章 Docker容器可视化监控中心搭建 微服务调用链追踪中心搭建 利用ELK搭建Docker容器化应用日志中心


回复

使用道具 举报