Spring Boot Admin 并不是 Spring Boot 官方出品的,开源地址 SpringBoot Admin ,伴随着 SpringBoot 的更新, Spring Boot Admin 也做了相对应的更新。Spring Boot 推出 2.X 版本时, Spring Boot Admin 也及时进行了更新。本篇使用的就是 Spring Boot Admin 2.2.1版本,最新版本是 2.2.2 。 Spring Boot Admin 分为 client 和 server 端, server 端一般独立为一个服务, client 可以是你已经开发完成的服务,也可以是你即将要开发的服务。
对 Spring Boot Admin 2.x 版本的具体的更新内容和变化感兴趣的朋友,可以参考 changes-2.x.adoc 文档,这里不再赘述。
继上一篇 微服务-Actuator实现服务监测 ,本篇继续学习微服务的管理知识。本篇主要内容,如下:
spring-boot-admin-server ; spring-boot-admin-client 和 spring-boot-security 如何配置且被注册到 spring-boot-admin-server ; spring-boot-admin-server 结合 spring-boot-security ,实现安全管控; 完整工程代码,请移步 Github 下载。后续会结合 spring-cloud 中的 Eureka 组件再次学习和分享使用 spring-boot-admin 。
为了学习和验证 Spring Boot Admin 的使用,我创建了一个 Admin-Server 工程即 ms-admin ,创建了两个 Admin-Client 工程即 ms-user 和 ms-admin-client ,工程结构如下图:
ms-user 和 ms-admin-client 不同点在于: ms-user 使用了 spring-boot-security 模块,而 ms-admin-client 没有使用 spring-boot-security 模块,是一个相对比较简单的 SpringBoot 服务。
ms-admin 在该 module 的 properties 文件中,配置如下:
spring.application.name=Admin-Server # --------------------------------- # 配置该服务的独立端口 # --------------------------------- server.port=8087
注意:该服务的端口为 8087 。
该 module 的 pom 文件,使用了 spring-boot 版本为 2.2.6.RELEASE , spring-boot-admin 版本为 2.2.1 ,这里一定要注意版本的匹配,否则工程运行会存在各种奇葩问题。这里教大家一个方法,如果你不知道如何匹配版本,直接使用 spring initializr 创建工程,然后下载创建的工程,看一下里面的 pom文件中各个模块的版本号就可以了。
修改一下启动类,增加 @EnableAdminServer 注解,如下:
import de.codecentric.boot.admin.server.config.EnableAdminServer;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@EnableAdminServer
@SpringBootApplication
public class MZAdminApplication{
public static void main(String[] args){
SpringApplication.run(MZAdminApplication.class, args);
}
}
ms-admin-client 在该 module 的 properties 文件中,配置如下:
spring.application.name=Admin-Client server.port=8083 # ------------------------ # Actuator config # ------------------------ # 可以访问任意控制点 management.endpoints.web.exposure.include=* # ------------------------------------------ # 配置 spring boot admin # ------------------------------------------ spring.boot.admin.client.url=http://localhost:8087 management.endpoint.health.show-details=always
注意:该服务的端口为 8083 。如果 admin-client 和 admin-server 没有部署在同一台服务器,这里的 spring.boot.admin.client.url 一定要写上 admin-server 所在服务器的ip地址。
在该 module 的 pom 文件中,引入如下依赖即可,如下:
<!-- springboot admin client -->
<dependency>
<groupId>de.codecentric</groupId>
<artifactId>spring-boot-admin-client</artifactId>
<version>2.2.1</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
其余的不需要修改任何东西。
分别启动 ms-admin 、 ms-admin-client ,启动成功后,在浏览器中打开 http://localhost:8087 就可以看到如下效果,可以看到 ms-admin-client 被发现了。
点进去,可以看到 ms-admin-client 的运行状况。大家可以自己试试,我就不截图了。
上面我们说了, ms-user 也是一个 Admin-Client,我也希望他能被监控和管理,但是 ms-user 有点特殊它使用了 security 模块,那么如何让他被 Admin-Server 发现呢,我们接着往下看。
PS: ms-user 模块其实是我之前一直在微服务相关文章 中使用的工程模块,这里只是重构了一下工程结构并且修改了一下名称而已。
因为 ms-user 包含了比较多的内容,其 pom 文件也相对复杂一些,这里粘贴一部分(MySQL和Swagger相关配置就不写了)。
spring.application.name=User-Server
# ------------------------
# Actuator config
# ------------------------
# 可以访问任意控制点
management.endpoints.web.exposure.include=*
# 配置独立的端口
management.server.port=1012
# 自定义访问控制点的路径
management.endpoints.web.base-path=/monitor
management.endpoint.shutdown.enabled=true
# -----------------------------------------------
# Spring Security Default user name and password
# -----------------------------------------------
spring.security.user.name=admin
spring.security.user.password=admin
spring.security.user.roles=ACTUATOR_ADMIN
# ------------------------------------------
# 配置 spring boot admin
# ------------------------------------------
spring.boot.admin.client.url=http://localhost:8087
management.endpoint.health.show-details=always
# 告诉admin-server用户名和密码,否则监控不到
spring.boot.admin.client.instance.metadata.user.name=${spring.security.user.name}
spring.boot.admin.client.instance.metadata.user.password=${spring.security.user.password}
这里要特别注意, ms-user 使用了security并且设置了用户名和密码,一定要告诉 Admin-Server,否则无法被监控到。也就是说如下的配置必须写:
# 告诉admin-server用户名和密码,否则监控不到
spring.boot.admin.client.instance.metadata.user.name=${spring.security.user.name}
spring.boot.admin.client.instance.metadata.user.password=${spring.security.user.password}
紧接着我们启动 ms-user 这个服务,刷新一下浏览器,效果如下图:
可以看到 ms-user 这个服务被如愿以偿的发现了。
在 ms-admin 的 pom 文件中引入 security 模块,如下:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-security</artifactId>
</dependency>
修改 properties 文件,增加用户名和密码的配置,完整配置如下:
spring.application.name=Admin-Server # --------------------------------- # 配置该服务的独立端口 # --------------------------------- server.port=8087 # --------------------------------- # security 配置 # --------------------------------- spring.security.user.name=admin spring.security.user.password=admin
配置完成后,我们分别重新启动一下 ms-admin 、 ms-admin-client 这两个服务。
再次打开 localhost:8087 ,会出现如下界面:
输入在 properties 文件中配置的用户名和密码,这里我配置的用户名和密码都是 admin ,你也可以配置其他的。
输入之后可以看到如下界面,再次输入上面的用户名和密码即可。
初次进入显示效果如下截图,居然没有发现 ms-admin-client 这个服务。
这是因为没有在客户端配置进入 Admin-Server 的密码,安排上。
在 ms-admin-client 的 properties 中配置,如下:
# ------------------------------------------ # 配置 spring boot admin # ------------------------------------------ spring.boot.admin.client.url=http://localhost:8087 management.endpoint.health.show-details=always # 配置 admin server 的用户名和密码,否则注册不上 spring.boot.admin.client.username=admin spring.boot.admin.client.password=admin
同理,在 ms-user 的配置文件 properties 中也增加相关的配置即可。
重新启动服务,就可以看到如下界面:
另外,Admin-Server 还可以集成 spring-boot-starter-mail 模块再简单的配置一下,就可以实现发送邮件的功能,这样服务的运行状态可以及时通知到对应的收件人了。