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
模块再简单的配置一下,就可以实现发送邮件的功能,这样服务的运行状态可以及时通知到对应的收件人了。