Spring Boot Admin 環(huán)境搭建與基本使用詳解
一、Spring Boot Admin是什么
它是用于監(jiān)控和管理Spring Boot應(yīng)用程序的開(kāi)源工具。它為開(kāi)發(fā)人員或者是運(yùn)維人員提供了友好的Web界面??梢詫?shí)時(shí)監(jiān)控和管理部署在不同環(huán)境中的Spring Boot應(yīng)用。
二、提供了那些功能
- 應(yīng)用程序監(jiān)控:可以顯示程序的基本信息:內(nèi)存使用情況、線(xiàn)程信息。
- 應(yīng)用程序管理:可以管理監(jiān)控的應(yīng)用:動(dòng)態(tài)配置日志的級(jí)別。
- 通知和報(bào)警:可以配置通知和警報(bào),當(dāng)應(yīng)用程序出現(xiàn)問(wèn)題或者叨叨預(yù)定的閾值時(shí)及時(shí)通知相關(guān)人員。
- 微服務(wù)支持:可以適用微服務(wù)架構(gòu),一次性監(jiān)控和管理多個(gè)微服務(wù)應(yīng)用。
- 安全性:可以與Spring Security集成,實(shí)現(xiàn)對(duì)監(jiān)控和管理界面的訪(fǎng)問(wèn)控制。
三、 使用Spring Boot Admin
示例項(xiàng)目整體結(jié)構(gòu):這里為什么要使用Eureka,主要是想體現(xiàn)復(fù)用的思想。所有服務(wù)都注冊(cè)到了Eureka之后,而Spring Boot Admin只要集成了Eureka之后就能夠獲取到所有的服務(wù)信息注冊(cè)信息。能夠?qū)λ凶?cè)到Eureka中的服務(wù)進(jìn)行監(jiān)控和管理。

Eureka的搭建可以參考這篇博客:【Spring Cloud 三】Eureka服務(wù)注冊(cè)與服務(wù)發(fā)現(xiàn)
3.1搭建Spring Boot Admin服務(wù)
pom文件
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.3.12.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.wangwei</groupId>
<artifactId>admin-server-05</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>05-admin-server</name>
<description>05-admin-server</description>
<properties>
<java.version>8</java.version>
<spring-boot-admin.version>2.3.0</spring-boot-admin.version>
<spring-cloud.version>Hoxton.SR12</spring-cloud.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>de.codecentric</groupId>
<artifactId>spring-boot-admin-starter-server</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>${spring-cloud.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
<dependency>
<groupId>de.codecentric</groupId>
<artifactId>spring-boot-admin-dependencies</artifactId>
<version>${spring-boot-admin.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>yml配置文件
##???
server:
port: 10086 #端口號(hào) 0-65535
spring:
application:
name: admin-server
eureka:
client:
service-url:
defaultZone: http://localhost:8761/eureka
register-with-eureka: true #設(shè)置為fasle 不往eureka-server注冊(cè),默認(rèn)為true
fetch-registry: true #應(yīng)用是否拉取服務(wù)列表到本地
registry-fetch-interval-seconds: 10 #為了緩解服務(wù)列表的臟讀問(wèn)題,時(shí)間越短臟讀越少 性能相應(yīng)的消耗回答
instance: #實(shí)例的配置
instance-id: ${eureka.instance.hostname}:${spring.application.name}:${server.port}
hostname: localhost #主機(jī)名稱(chēng)或者服務(wù)ip
prefer-ip-address: true #以ip的形式顯示具體的服務(wù)信息
lease-renewal-interval-in-seconds: 10 #服務(wù)實(shí)例的續(xù)約時(shí)間間隔
management:
endpoints:
web:
exposure:
include: '*' #暴露所有的監(jiān)控端點(diǎn) #如果一個(gè)服務(wù)需要被監(jiān)控,那么就要將自身的一些清苦(一些信息接口)暴露出去啟動(dòng)類(lèi)
@SpringBootApplication
@EnableEurekaClient
@EnableAdminServer //#開(kāi)啟admin服務(wù)端
public class AdminServerApplication {
public static void main(String[] args) {
SpringApplication.run(AdminServerApplication.class, args);
}
}啟動(dòng)admin服務(wù)效果

3.2 common-api
這個(gè)模塊是抽離出來(lái)的提供接口用于兩個(gè)服務(wù)之間的跨服務(wù)調(diào)用。之后由服務(wù)消費(fèi)者集成。
pom文件
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<parent>
<artifactId>feign-project</artifactId>
<groupId>com.wangwei</groupId>
<version>1.0-SNAPSHOT</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>common-api</artifactId>
<properties>
<maven.compiler.source>8</maven.compiler.source>
<maven.compiler.target>8</maven.compiler.target>
</properties>
<dependencies>
<dependency>
<groupId>com.wangwei</groupId>
<artifactId>project-domain</artifactId>
<version>1.0-SNAPSHOT</version>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-hystrix</artifactId>
</dependency>
</dependencies>
</project>feign
@FeignClient(value = "order-service",fallback = UserOrderFeignHystrix.class)
public interface UserOrderFeign {
@GetMapping("order/getOrderByUserId/{id}")
Order getOrderByUserId (@PathVariable("id")Integer id);
}hystrix
@Component
public class UserOrderFeignHystrix implements UserOrderFeign {
/**
* 一般遠(yuǎn)程調(diào)用的熔斷可以直接返回null
* @param id
* @return
*/
@Override
public Order getOrderByUserId(Integer id) {
return null;
}
}3.3服務(wù)消費(fèi)者
pom文件
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<parent>
<artifactId>feign-project</artifactId>
<groupId>com.wangwei</groupId>
<version>1.0-SNAPSHOT</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>user-center</artifactId>
<properties>
<maven.compiler.source>8</maven.compiler.source>
<maven.compiler.target>8</maven.compiler.target>
</properties>
<dependencies>
<!--用于在應(yīng)用程序中添加各種監(jiān)控和管理功能-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
<dependency>
<groupId>com.wangwei</groupId>
<artifactId>common-api</artifactId>
<version>1.0-SNAPSHOT</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
</dependencies>
</project>yml配置文件
server:
port: 8081
spring:
application:
name: user-service
eureka:
client:
service-url: #??????
defaultZone: http://localhost:8761/eureka
register-with-eureka: true #設(shè)置為fasle 不往eureka-server注冊(cè)
fetch-registry: true #應(yīng)用是否拉取服務(wù)列表到本地
registry-fetch-interval-seconds: 10 #為了緩解服務(wù)列表的臟讀問(wèn)題,時(shí)間越短臟讀越少 性能相應(yīng)的消耗回答
instance: #實(shí)例的配置
instance-id: ${eureka.instance.hostname}:${spring.application.name}:${server.port}
hostname: localhost #主機(jī)名稱(chēng)或者服務(wù)ip
prefer-ip-address: true #以ip的形式顯示具體的服務(wù)信息
lease-renewal-interval-in-seconds: 10 #服務(wù)實(shí)例的續(xù)約時(shí)間間隔
feign:
hystrix:
enabled: true #開(kāi)啟熔斷
management:
endpoints:
web:
exposure:
include: '*'啟動(dòng)類(lèi)
@SpringBootApplication
@EnableEurekaClient
@EnableFeignClients
public class UserServiceApplication {
public static void main(String[] args) {
SpringApplication.run(UserServiceApplication.class,args);
}
}controller
@RestController
public class UserController {
@Autowired
private UserOrderFeign userOrderFeign;
@GetMapping("findOrder")
public Order findOrder(){
return userOrderFeign.getOrderByUserId(1);
}
}3.4服務(wù)提供者
服務(wù)提供者與服務(wù)消費(fèi)者的主要區(qū)別是沒(méi)有依賴(lài)actuator以及對(duì)應(yīng)的暴露端點(diǎn)的配置。所以在admin的Web頁(yè)面中是不為看到服務(wù)提供者的詳細(xì)信息。
<!--用于在應(yīng)用程序中添加各種監(jiān)控和管理功能-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>pom文件
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<parent>
<artifactId>feign-project</artifactId>
<groupId>com.wangwei</groupId>
<version>1.0-SNAPSHOT</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>order-center</artifactId>
<properties>
<maven.compiler.source>8</maven.compiler.source>
<maven.compiler.target>8</maven.compiler.target>
</properties>
<dependencies>
<dependency>
<groupId>com.wangwei</groupId>
<artifactId>common-api</artifactId>
<version>1.0-SNAPSHOT</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>yml配置文件
server:
port: 8080
spring:
application:
name: order-service
eureka:
client:
service-url: #??????
defaultZone: http://localhost:8761/eureka
register-with-eureka: true #設(shè)置為fasle 不往eureka-server注冊(cè)
fetch-registry: true #應(yīng)用是否拉取服務(wù)列表到本地
registry-fetch-interval-seconds: 10 #為了緩解服務(wù)列表的臟讀問(wèn)題,時(shí)間越短臟讀越少 性能相應(yīng)的消耗回答
instance: #實(shí)例的配置
instance-id: ${eureka.instance.hostname}:${spring.application.name}:${server.port}
hostname: localhost #主機(jī)名稱(chēng)或者服務(wù)ip
prefer-ip-address: true #以ip的形式顯示具體的服務(wù)信息
lease-renewal-interval-in-seconds: 10 #服務(wù)實(shí)例的續(xù)約時(shí)間間隔項(xiàng)目啟動(dòng)類(lèi)
@SpringBootApplication
@EnableEurekaClient
public class OrderServiceApplication {
public static void main(String[] args) {
SpringApplication.run(OrderServiceApplication.class,args);
}
}controller
@RestController
public class OrderController {
@GetMapping("order/getOrderByUserId/{id}")
Order getOrderByUserId (@PathVariable("id")Integer id){
System.out.println(id);
Order order=Order.builder()
.name("青椒肉絲蓋飯")
.price(15D)
.orderId(1)
.build();
return order;
}
}服務(wù)整體啟動(dòng)之后的效果



由于Eureka服務(wù)沒(méi)有依賴(lài)actuator所以不能看到詳細(xì)信息。

四、 總結(jié)
- 本篇博客主要是對(duì)于Spring Boot Admin的基本認(rèn)識(shí)和基本運(yùn)用,通過(guò)本篇博客能夠?qū)pring Boot Admin有一個(gè)宏觀認(rèn)知和能夠快速上手。
- Spring Boot Admin還可以設(shè)置通知可報(bào)警,本篇博客并沒(méi)有涉及到。
到此這篇關(guān)于Spring Boot Admin 環(huán)境搭建與基本使用的文章就介紹到這了,更多相關(guān)Spring Boot Admin搭建內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java使用Hutool+自定義注解實(shí)現(xiàn)數(shù)據(jù)脫敏
我們?cè)谑褂檬謾C(jī)銀行的時(shí)候經(jīng)常能看到APP上會(huì)將銀行卡的卡號(hào)中間部分給隱藏掉使用 ***** 來(lái)代替,在某些網(wǎng)站上查看一些業(yè)務(wù)密碼時(shí)(例如簽到密碼等)也會(huì)使用 ***** 來(lái)隱藏掉真正的密碼,那么這種方式是如何實(shí)現(xiàn)的呢,本文將給大家介紹使用Hutool+自定義注解實(shí)現(xiàn)數(shù)據(jù)脫敏2023-09-09
解決Spring security5.5.7報(bào)錯(cuò)Encoded password does
這篇文章主要介紹了解決Spring security5.5.7出現(xiàn)Encoded password does not look like BCrypt異常問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-08-08
Java8的Stream()與ParallelStream()的區(qū)別說(shuō)明
這篇文章主要介紹了Java8的Stream()與ParallelStream()的區(qū)別說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-07-07
Java中字符串與日期類(lèi)型的相互轉(zhuǎn)換示例代碼
這篇文章主要給大家介紹了關(guān)于Java中字符串與日期類(lèi)型的相互轉(zhuǎn)換的相關(guān)資料,將Java(或任何編程語(yǔ)言)中的字符串轉(zhuǎn)換為日期是一項(xiàng)基本技能,對(duì)于在項(xiàng)目上進(jìn)行工作很有用需要的朋友可以參考下2023-08-08
Java設(shè)計(jì)模式之java模板方法模式詳解
這篇文章主要介紹了Java設(shè)計(jì)模式模板方法模式(Template)用法解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2021-09-09
java實(shí)現(xiàn)的簡(jiǎn)單猜數(shù)字游戲代碼
這篇文章主要介紹了java實(shí)現(xiàn)的簡(jiǎn)單猜數(shù)字游戲代碼,通過(guò)隨機(jī)數(shù)與邏輯判斷來(lái)實(shí)現(xiàn)游戲功能,具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2014-11-11
Spring Cloud多個(gè)微服務(wù)之間調(diào)用代碼實(shí)例
這篇文章主要介紹了Spring Cloud多個(gè)微服務(wù)之間調(diào)用代碼實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-12-12
Java使用JDBC實(shí)現(xiàn)Oracle用戶(hù)認(rèn)證的方法詳解
這篇文章主要介紹了Java使用JDBC實(shí)現(xiàn)Oracle用戶(hù)認(rèn)證的方法,結(jié)合實(shí)例形式分析了java使用jdbc實(shí)現(xiàn)數(shù)據(jù)庫(kù)連接、建表、添加用戶(hù)、用戶(hù)認(rèn)證等操作流程與相關(guān)注意事項(xiàng),需要的朋友可以參考下2017-08-08
SpringMVC配置javaConfig及StringHttpMessageConverter示例
這篇文章主要介紹了SpringMVC配置javaConfig及StringHttpMessageConverter實(shí)現(xiàn)示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-07-07
Java使用Jsoup解析html網(wǎng)頁(yè)的實(shí)現(xiàn)步驟
Jsoup是一個(gè)用于解析HTML文檔的Java庫(kù),本文主要介紹了Java使用Jsoup解析html網(wǎng)頁(yè)的實(shí)現(xiàn)步驟,可以提取文本、鏈接、圖片等,具有一定的參考價(jià)值,感興趣的可以了解一下2024-02-02

