一、简介
如何对SpringBoot项目进行监控呢?比如健康度、运行指标、日志信息、线程状况等信息,本文介绍的是利用 Spring Boot Admin 项目进行监控。
    Spring Boot Admin 这个项目是在Spring原生的监控插件Actuator的基础上进行了一些些改动,尤其是改变了不太美观的 UI,所以说这是一套成熟的监控系统,而且几乎可以拆箱即用。
小插曲,这个项目是德国的一家叫做 codecentric 的软件公司写的,这家公司写了蛮多的 Spring Boot 周边插件,值得一看,地址:https://github.com/codecentric。
    最后,附上文档地址,文档写得很直观、易懂:http://codecentric.github.io/spring-boot-admin/1.5.7/#_what_is_spring_boot_admin。
本文的 server 端代码地址:https://github.com/goldenJet/SpringBootAdminServer.git。</p>
二、应用
    1)整体架构
        由一个服务端和多个客户端组成。
        服务端就是我们单独构建的一个 Spring Boot Admin 项目,用于监控我们的需要被监控的项目。
        客户端就是我们自己的 SpringBoot 项目,即需要被监控的项目。
        我们只需要在客户端内配置好服务端的地址,然后客户端向服务端发送被监控的请求,之后服务端便会定时请求客户端的接口获得客户端的应用状态信息。
    2)服务端实现
① 新建一个 SpringBoot 项目,引入 Spring Boot Admin starter Server 的包,
1  | <dependency>  | 
        你进入源码会发现,这一个 starter 其实是引入了两个重要的包:
1  | <dependency>  | 
② 需要在启动类上面增加注解 @EnableAdminServer
1  | @SpringBootApplication  | 
③ 在application.properties 中指定端口
1  |     server.port=8081  | 
        其实经过①②两步的代码逻辑,监控server就已经写好了,启动项目,访问 localhost:8081即可访问监控server的UI。
            
    3)客户端实现
        服务端已经部署好了,接下来配置客户端。
        ① 客户端引入 client 包:
1  | <dependency>  | 
② 修改配置:
1  | spring.boot.admin.url=http://localhost:8080    | 
说明:
配置第一行交代了服务端的项目访问地址,
                第二行:由于自Spring1.5开始,所有的 Endpoint都是默认安全的,即关闭的,所以要手动设置成 false,
            官方说明文档:
            
            到此,其实客户端也已经简单配置好了,启动项目,重新访问服务端网页,发现有服务已经注册进来了,然后我们便可以查看该服务的各项基本信息:

    4)服务端开启安全校验
        注意,此时的服务端是不需要进行登录的,所以如果我们想添加一个登录页面和登录按钮,则需要增加一些额外的配置,效果如图:
        
        实现方式:
        ① 添加登录的ui包和 Spring Security 包:
1  | <dependency>  | 
        ② 在配置文件中添加默认的登录用户名和密码:
1  | security.user.name=admin  | 
        ③ 添加 SpringSecurity 的配置类
1  | /**  | 
            搞定!
三、注意点
    以下都是一些配置的小问题,在本文开头提供的文档地址内都能找到对应的解决方案。
    ① 如果 client 端有类似 Spring Security 之类的权限控制程序,则会造成 /health/ 等接口的访问被拒绝,因为服务端监控客户端应用的状态是调用如下接口来查看信息的,所以这些接口的限制需要放开,如SpringSecurity 则可以进行如下的配置:
        
        
② client 端服务的注册,默认是以当前系统的用户名来注册的,即会以 hostname:port 来注册
所以要改成以 IP 地址的形式来注册,只需要在 client 端添加主配置:spring.boot.admin.client.prefer-ip=true 即可。
但是如果以 IP 地址的形式访问,由于 IP 的获取时通过 InetAddress.getLocalHost() 来获取的,所以有时会出现 IP地址是 127.0.0.1 的情况,从而导致server 端无法请求到 client 端的程序。
        终极解决办法:
在 client 端使用如下配置指定项目的地址:spring.boot.admin.client.service-base-url=http://192.168.154.77:9090
    ③ 我们也可以在 client 端命名该客户端
spring.boot.admin.client.name=adminClient