鍍金池/ 教程/ Java/ 通過JMX監(jiān)控Spring Boot應(yīng)用
通過JMX監(jiān)控Spring Boot應(yīng)用
Spring Boot:定制PropertyEditors
配置是否初始化Bean的方法
Spring Boot的自動配置、Command-line Runner
Spring Boot:定制URL匹配規(guī)則
Spring Boot的自動配置、Command-line Runner
利用Mockito模擬DB
Spring Boot應(yīng)用的打包和部署
了解Spring Boot的自動配置
Spring Boot應(yīng)用的健康監(jiān)控
了解Spring Boot的自動配置
初始化數(shù)據(jù)庫和導(dǎo)入數(shù)據(jù)
Spring Boot應(yīng)用的健康監(jiān)控
Docker with Spring Boot
RESTful by Spring Boot with MySQL
Spring Boot:定制攔截器
Spring Boot:定制static path mappings
Spring Boot with Mysql
Spring Boot:定制自己的starter
在測試中使用內(nèi)存數(shù)據(jù)庫
Restful: Spring Boot with Mongodb
Spring Boot with Redis
Spring Boot:定制HTTP消息轉(zhuǎn)換器
Spring Boot: Data Rest Service
Spring Boot:定制type Formatters
在Spring Boot項目中使用Spock框架
選擇Spring Boot項目的內(nèi)嵌容器
通過EmbeddedServletContainerCustomizer接口調(diào)優(yōu)Tomcat
Spring Boot應(yīng)用的打包和部署
Spring Boot Admin的使用
讓你的Spring Boot工程支持HTTP和HTTPS
Spring Boot:定制servlet filters
Spring Boot:定制URL匹配規(guī)則
Spring Boot應(yīng)用的測試——Mockito
Spring Boot應(yīng)用的測試——Mockito
Spring Boot:定制servlet filters
通過@Enable*注解觸發(fā)Spring Boot配置

通過JMX監(jiān)控Spring Boot應(yīng)用

Spring Boot應(yīng)用的健康監(jiān)控一文中,我們通過Spring Boot Actuator對外暴露應(yīng)用的監(jiān)控信息,除了使用HTTP獲取JSON格式 的數(shù)據(jù)之外,還可以通過JMX監(jiān)控應(yīng)用,Spring Boot也提供了對JMX監(jiān)控的支持。JMX監(jiān)控對外暴露的信息相同,不過是使用MBeans容器將應(yīng)用數(shù)據(jù)封裝管理。

接下來我們看下如何利用JMX獲取應(yīng)用狀態(tài)信息,以及如何使用Jolokia JMX庫對外暴露MBeans的HTTP訪問URL。

Get Ready

在BookPub應(yīng)用的pom文件中添加jolokia-core依賴

<!-- JMX monitor -->
<dependency>
   <groupId>org.jolokia</groupId>
   <artifactId>jolokia-core</artifactId>
</dependency>

How Do

  1. 啟動BookPub應(yīng)用,然后在命令行中執(zhí)行jconsole命令啟動“Java管理和監(jiān)視控制臺”,然后選擇org.springframework.boot節(jié)點下的Endpoint,可以看到如下信息 http://wiki.jikexueyuan.com/project/spring-boot-cookbook-zh/images/2.png" alt="Java管理和監(jiān)視控制臺" />

  2. Tomcat節(jié)點下選擇ThreadPool,然后在選擇http-nio-8080節(jié)點,在這個節(jié)點下選擇maxThreads屬性,可以看到如下信息 http://wiki.jikexueyuan.com/project/spring-boot-cookbook-zh/images/1e.png" alt="查看應(yīng)用的最大并發(fā)線程數(shù)" />

  3. 除了通過JMX獲取信息,也暴露了對應(yīng)的HTTP接口訪問Mbeans對象的信息,例如,我們在postman中訪問http://localhost:8080/jolokia/read/Tomcat:type=ThreadPool,name=%22http-nio-8080%22/maxThreads,也可以得到對應(yīng)的信息 http://wiki.jikexueyuan.com/project/spring-boot-cookbook-zh/images/ac.png" alt="通過HTTP訪問應(yīng)用的最大并發(fā)線程數(shù)" />

分析

只要添加了Spring Boot Actuator庫,所有相關(guān)的endpoint和管理服務(wù)都打開了,包括JMX,我們可以通過設(shè)置endpoints.jmx.enabled=false禁止對外提供基于JMX的endpoints;或者通過設(shè)置spring.jmx.enabled=false禁止對外提供Spring MBeans。

在類路徑中存在的Jolokia庫會觸發(fā)Spring Boot的JolokiaAutoConfiguration,這個自動配置類會自動配置可以接受/jolokia請求的JolokiaMvcEndPoint;也可以通過在application.properties中設(shè)置jolokia.config.系列的屬性配置不同的Jolokia配置。完整的Jolokia配置地址在:https://jolokia.org/reference/html/agents.html#agent-war-init-params。如果你希望定制自己的Jolokia配置,則可以通過設(shè)置endpoints.jolokia.enabled=false*讓Spring Boot應(yīng)用忽略自身提供的配置。