spring通过annotation注册MBean到JMX

本文介绍如何使用Spring框架通过注解的方式暴露MBean,包括@ManagedResource、@ManagedAttribute和@ManagedOperation等注解的用法,并提供XML配置示例。
部署运行你感兴趣的模型镜像

1、前言

JMX管理及使用日趋成熟。spring对bean的管理功能也很强大,通过annotation把某些方法暴露成MBean,然后通过JMX远程管理,在某些场景下会带来意想不到的效果。

 

本文只介绍两个内容:spring通过annotation暴露MBean、相关的xml配置。

 

 

2、spring通过annotation暴露MBean

 

      2.1   涉及到三个重要的annotation:@ManagedResource @ManagedAttribute 和 @ManagedOperation。

 

用途Commons Attributes属性JDK 5.0注解属性/注解类型
将类的所有实例标识为JMX受控资源 ManagedResource @ManagedResource Class 类
将方法标识为JMX操作 ManagedOperation @ManagedOperation Method方法
将getter或者setter标识为部分JMX属性 ManagedAttribute @ManagedAttribute Method (only getters and setters) 方法(仅getters和setters)
定义操作参数说明 ManagedOperationParameter @ManagedOperationParameter@ManagedOperationParameters Method 方法

 

 

    2.2   看了上面官方解释,应该有个大概的了解,下面再举个例子。

 

@ManagedResource(objectName="bean:name=lionbuleTest", description="My Managed Bean")
public class AnnotationTestMBean{
	private String name;
	private int age;
	
	@ManagedAttribute(description="The Name Attribute")
	public void setName(String name) {
		this.name = name;
	}

	@ManagedAttribute()
	public String getName() {
		return name;
	}  
	public int getAge() {
		return age;
	}
	public void setAge(int age) {
		this.age = age;
	}
	
	@ManagedOperation(description="Add two numbers")
	@ManagedOperationParameters({
	@ManagedOperationParameter(name = "x", description = "The first number"),
	@ManagedOperationParameter(name = "y", description = "The second number")})
	public int add_1(int x, int y) {
		return x + y;
	}

	@ManagedOperation
	public int add_2(int x, int y){
		return x + y;
	}
  
	public void dontExposeMe() {
		throw new RuntimeException();
	}

}

 

   2.3  Jconsole的管理界面截图:

 

图1、查看已暴露MBean的属性

查询bean的属性

 

图2、查看已暴露MBean的方法

查看MBean的方法

 

   2.4   解释说明:

 

         1、@ManagedResource @ManagedAttribute 和 @ManagedOperation 还有许多参数,具体使用请参考spring官方手册。( spring手册[2.5.3] ---- 20.3.4. 源代码级的元数据类型)

 

         2、@ManagedOperationParameters 是对@ManagedOperation的补充。具体看代码样例中的add1方法上的注解,然后再看图2(查看已暴露MBean的方法)的add1方法和add2的区别。添加参数说明的add1方法会显示出参数名,而add2方法则是默认的参数名p1/p2。

 

         3、没有添加@ManagedOperation和@ManagedAttribute的方法,在图2中就没有看到,说明添加了注解的方法暴露MBean是可用的。

 

         4、@ManagedOperation和@ManagedAttribute的区别,请查看2.1的详解。

 

3、xml配置

    方式一、通用spring bean配置

    <bean id="jmxAttributeSource"
          class="org.springframework.jmx.export.annotation.AnnotationJmxAttributeSource"/>
    <!-- 使用注解元数据创建管理接口 -->
    <bean id="assembler"
          class="org.springframework.jmx.export.assembler.MetadataMBeanInfoAssembler">
        <property name="attributeSource" ref="jmxAttributeSource"/>
    </bean>
    <!-- 从注解中得到ObjectName  -->
    <bean id="namingStrategy"
          class="org.springframework.jmx.export.naming.MetadataNamingStrategy">
        <property name="attributeSource" ref="jmxAttributeSource"/>
    </bean>
    <bean id="exporter" class="org.springframework.jmx.export.MBeanExporter">
        <property name="assembler" ref="assembler"/>
        <property name="namingStrategy" ref="namingStrategy"/>
        <property name="autodetect" value="true"/>
    </bean>
	
	<!-- 配置服务器端连接器RMI -->
	<bean class="org.springframework.remoting.rmi.RmiRegistryFactoryBean">		
		<property name="port" value="2088"/>
	</bean>
	<bean id="serverConnector"
	      class="org.springframework.jmx.support.ConnectorServerFactoryBean">
	  <property name="objectName" value="connector:name=rmi"/>
          <!-- 客户端链接地址配置 -->
	  <property name="serviceUrl"
	            value="service:jmx:rmi://localhost/jndi/rmi://localhost:2088/myconnector"/>
	</bean>

	<!-- 自定义的mbean -->
    <bean id="annotationTestMBean" class="com.lionbule.biz.test.AnnotationTestMBean">
        <property name="name" value="TEST"/>
        <property name="age" value="100"/>
    </bean>

    配置中,已经加了相应的注释。还不是很清楚,可以查询spring官方手册。

 

    方式二、简化spring-context配置

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xmlns:context="http://www.springframework.org/schema/context"
	xsi:schemaLocation="http://www.springframework.org/schema/beans
	                    http://www.springframework.org/schema/beans/spring-beans.xsd
	                    http://www.springframework.org/schema/context
	                    http://www.springframework.org/schema/context/spring-context.xsd"
	default-autowire="byName">

	<context:mbean-export default-domain="ShowCase" registration="replaceExisting" />
	<!-- 自定义的mbean -->
    <bean id="annotationTestMBean" class="com.lionbule.biz.test.AnnotationTestMBean">
        <property name="name" value="TEST"/>
        <property name="age" value="100"/>
    </bean>
</beans>

    注意:方式二对ClassName和beanName有约束,请以‘MBean’结尾。 

 

4、客户端工具连接

 

    常用的客户端工具:Jconsole、jvisualvm、jmanager等。

    连接方式有多种,但本案只介绍了RMI连接管理,所以本案的链接地址为:

service:jmx:rmi://localhost/jndi/rmi://localhost:2088/myconnector

 

参考资料:

1、spring官方手册

     http://static.springsource.org/spring/docs/2.5.x/reference/jmx.html#jmx-interface

2.  http://wiki.springside.org.cn/display/SpringSide3/JMX

 

 

您可能感兴趣的与本文相关的镜像

Stable-Diffusion-3.5

Stable-Diffusion-3.5

图片生成
Stable-Diffusion

Stable Diffusion 3.5 (SD 3.5) 是由 Stability AI 推出的新一代文本到图像生成模型,相比 3.0 版本,它提升了图像质量、运行速度和硬件效率

<think>我们正在讨论Spring Boot中的两个特性:调试输出和JMX代理。它们都是用于监控和管理应用程序的工具,但工作方式和目的有所不同。 1. **调试输出**: - 通常指的是在开发过程中启用调试日志输出,以便更详细地了解应用程序的运行情况。在Spring Boot中,我们可以通过设置日志级别(如`DEBUG`或`TRACE`)来获取更多信息。 - 调试输出主要用于开发和故障排除阶段,可以帮助开发者查看应用程序内部的操作,例如Spring Bean的创建、HTTP请求的处理细节、数据库查询等。 - 配置方式:通过`application.properties`或`application.yml`文件设置日志级别,或者通过命令行参数(如`--debug`)来启用Spring Boot的“调试模式”。 2. **JMX代理(Java Management Extensions)**: - JMX是一种Java标准,用于管理和监控应用程序。它提供了一种标准的方式,使应用程序可以暴露管理接口(MBeans),然后通过JMX客户端(如JConsole、VisualVM)连接到应用程序,查看和操作这些MBeans。 -Spring Boot中,默认会启用JMX,并自动将所有的Spring Bean注册MBeans(通过`EndpointMBeanExporter`),这样我们就可以通过JMX客户端来监控和管理Spring Boot应用的健康状况、配置、日志级别等。 - 此外,Spring Boot Actuator提供了更多的端点(endpoints),可以通过JMX暴露出来,从而允许远程管理。 主要区别: - **目的**:调试输出主要是为了开发人员查看日志,而JMX代理是为了提供应用程序的管理和监控功能。 - **使用方式**:调试输出是通过日志系统(如Logback、Log4j2)输出到控制台或文件;JMX代理是通过暴露MBeans接口,使用JMX客户端连接。 - **实时性**:JMX允许在运行时动态修改配置(如日志级别),而调试输出通常需要重启或更改配置才能调整日志级别(除非使用动态日志框架支持)。 下面我们来看如何在Spring Boot中配置这两个功能: ### 调试输出配置示例 在`application.properties`中启用调试模式(这将启用Spring Boot内置的一些调试日志): ```properties # 启用Spring Boot的调试模式(会输出更多的启动日志,但不会影响日志级别) debug=true # 或者,设置特定包的日志级别为DEBUG logging.level.org.springframework.web=DEBUG logging.level.com.example=DEBUG ``` ### JMX配置示例 默认情况下,Spring Boot会启用JMX。我们可以通过以下配置来禁用或自定义JMX: ```properties # 禁用JMX spring.jmx.enabled=false ``` 要使用Spring Boot Actuator来通过JMX暴露端点,首先需要添加Actuator依赖(在Maven项目中): ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-actuator</artifactId> </dependency> ``` 然后,在`application.properties`中配置暴露哪些端点(默认情况下,通过JMX暴露所有端点,而HTTP暴露的端点需要另外配置): ```properties # 通过JMX暴露所有端点 management.endpoints.jmx.exposure.include=* ``` 启动应用后,可以使用JConsole连接(通常在本地运行的应用可以直接在JConsole中看到,远程连接需要配置一些参数)。 ### 代码演示 下面是一个简单的Spring Boot应用,展示如何配置日志和JMX。 **主应用类**: ```java package com.example.demo; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; @SpringBootApplication public class DemoApplication { public static void main(String[] args) { SpringApplication.run(DemoApplication.class, args); } } ``` **一个简单的RestController**(用于测试日志): ```java package com.example.demo; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RestController; @RestController public class HelloController { private static final Logger logger = LoggerFactory.getLogger(HelloController.class); @GetMapping("/") public String hello() { logger.debug("This is a debug message"); logger.info("This is an info message"); return "Hello World"; } } ``` **配置`application.properties`**: ```properties # 启用调试模式(Spring Boot自身的调试信息) debug=true # 设置包com.example的日志级别为DEBUG logging.level.com.example=DEBUG # Actuator JMX配置:暴露所有端点(默认就是所有,这里显式配置) management.endpoints.jmx.exposure.include=* ``` ### 解释 - 当访问`/`端点时,由于我们设置的包`com.example`的日志级别为`DEBUG`,所以会输出`debug`和`info`级别的日志。 - 同时,由于启用了`debug=true`,Spring Boot在启动时会输出更多的启动信息(比如自动配置的报告)。 - JMX代理默认启用,并且我们通过Actuator暴露了所有端点,因此可以使用JConsole等工具连接,查看和管理应用。 ### 相关问题 根据要求,提出相关问题: §§相关问题§§: 1. 如何在Spring Boot中动态更改日志级别? 2. Spring Boot Actuator提供了哪些常用的监控端点? 3. 如何通过JMX远程连接Spring Boot应用? 4. 在Spring Boot中,如何自定义一个MBean并通过JMX暴露? </think>### Spring Boot调试输出与JMX代理的区别 **调试输出**和**JMX代理**是Spring Boot中两种不同的应用监控/调试机制: #### 1. 调试输出(Debug Output) - **目的**:开发期间实时查看应用内部状态 - **实现方式**:通过日志系统输出详细信息 - **典型配置**: ```properties # application.properties logging.level.org.springframework=DEBUG logging.level.com.example=TRACE ``` - **使用场景**: - 查看特定包的详细日志 - 跟踪HTTP请求处理流程 - 检查SQL语句执行情况 - 分析Bean生命周期事件 #### 2. JMX代理(JMX Agent) - **目的**:通过标准管理接口远程监控管理应用 - **实现方式**:暴露MBeans(管理Bean)接口 - **典型配置**: ```properties # application.properties spring.jmx.enabled=true # 暴露所有Actuator端点 management.endpoints.jmx.exposure.include=* ``` - **使用场景**: - 运行时通过JConsole/VisualVM查看内存/线程 - 动态修改日志级别(无需重启) - 监控HTTP请求指标 - 管理计划任务执行 ### 核心区别对比表 | 特性 | 调试输出 | JMX代理 | |--------------------|-----------------------------|----------------------------| | **主要目的** | 开发阶段日志诊断 | 生产环境应用管理 | | **访问方式** | 日志文件/控制台 | JMX客户端(JConsole/VisualVM)| | **实时性** | 需要查看日志文件 | 实时图形化监控 | | **动态修改** | 需重启应用(动态日志除外) | 支持运行时配置更改 | | **标准化** | 应用自定义日志格式 | Java标准管理接口(MBean) | | **远程管理** | 通常需要SSH访问日志 | 支持远程安全连接 | | **Spring Boot支持**| 日志系统集成 | Actuator+JMX自动暴露端点 | ### 代码示例:动态修改日志级别(JMX) ```java // JMX管理接口定义 public interface LoggingManagerMBean { void setLogLevel(String loggerName, String level); } // JMX实现类 @Component @ManagedResource(objectName = "com.example:type=LoggingManager") public class LoggingManager implements LoggingManagerMBean { private final LoggerContext loggerContext = (LoggerContext) LoggerFactory.getILoggerFactory(); @Override @ManagedOperation public void setLogLevel(String loggerName, String level) { ch.qos.logback.classic.Logger logger = loggerContext.getLogger(loggerName); logger.setLevel(Level.valueOf(level)); } } ``` ### 调试输出使用示例 ```java @RestController public class DemoController { private static final Logger logger = LoggerFactory.getLogger(DemoController.class); @GetMapping("/debug") public String debugEndpoint() { logger.debug("Debug message - visible only at DEBUG level"); logger.trace("Trace message - visible only at TRACE level"); return "Check console/logs"; } } ``` ### 关键区别解释: 1. **访问维度** 调试输出是单向的信息流(应用→日志),而JMX代理支持双向交互(读取状态+修改配置) 2. **生命周期** 调试输出通常在开发/测试阶段使用;JMX代理设计用于生产环境长期运行监控 3. **资源消耗** 详细调试输出可能产生大量IO操作;JMX代理仅在查询时消耗资源 4. **安全性** JMX支持SSL/TLS加密和密码认证;调试日志通常需要文件系统权限控制 5. **集成能力** JMX可对接监控系统(Prometheus+JMX Exporter);调试日志需要ELK等日志系统处理
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值