此版本仍在开发中,尚未被视为稳定版本。最新的稳定版本请使用 Spring Framework 6.1.13spring-doc.cn

此版本仍在开发中,尚未被视为稳定版本。最新的稳定版本请使用 Spring Framework 6.1.13spring-doc.cn

对于远程访问, Spring JMX 模块在包内提供了两种实现,用于创建服务器端和客户端 连接。FactoryBeanorg.springframework.jmx.supportspring-doc.cn

服务器端连接器

要让 Spring JMX 创建、启动和公开 JSR-160 ,您可以使用 以下配置:JMXConnectorServerspring-doc.cn

<bean id="serverConnector" class="org.springframework.jmx.support.ConnectorServerFactoryBean"/>

默认情况下,会创建一个绑定到 .因此,该 bean 公开了 通过 localhost 上的 JMXMP 协议,端口 9875 本地到客户端。注意 JMXMP 协议被 JSR 160 规范标记为可选。现在 主要的开源 JMX 实现 MX4J 和 JDK 随附的实现 不支持 JMXMP。ConnectorServerFactoryBeanJMXConnectorServerservice:jmx:jmxmp://localhost:9875serverConnectorMBeanServerspring-doc.cn

要指定另一个 URL 并向 注册自身,您可以分别使用 和 属性, 如下例所示:JMXConnectorServerMBeanServerserviceUrlObjectNamespring-doc.cn

<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:1099/myconnector"/>
</bean>

如果设置了该属性,Spring 会自动注册您的连接器 与下那 .以下示例显示了完整的 在创建时可以传递给 的参数:ObjectNameMBeanServerObjectNameConnectorServerFactoryBeanJMXConnectorspring-doc.cn

<bean id="serverConnector"
		class="org.springframework.jmx.support.ConnectorServerFactoryBean">
	<property name="objectName" value="connector:name=iiop"/>
	<property name="serviceUrl"
		value="service:jmx:iiop://localhost/jndi/iiop://localhost:900/myconnector"/>
	<property name="threaded" value="true"/>
	<property name="daemon" value="true"/>
	<property name="environment">
		<map>
			<entry key="someKey" value="someValue"/>
		</map>
	</property>
</bean>

请注意,当您使用基于 RMI 的连接器时,需要启动查找服务 ( 或 ) 才能完成名称注册。tnameservrmiregistryspring-doc.cn

客户端连接器

要创建远程 JSR-160-enabled ,可以使用 ,如下例所示:MBeanServerConnectionMBeanServerMBeanServerConnectionFactoryBeanspring-doc.cn

<bean id="clientConnector" class="org.springframework.jmx.support.MBeanServerConnectionFactoryBean">
	<property name="serviceUrl" value="service:jmx:rmi://localhost/jndi/rmi://localhost:1099/jmxrmi"/>
</bean>

JMX over Hessian 或 SOAP

JSR-160 允许扩展客户端之间的通信方式 和服务器。前面各节中显示的示例使用基于 RMI 的强制实现 JSR-160 规范(IIOP 和 JRMP)和(可选)JMXMP 要求。通过使用 其他提供程序或 JMX 实现(例如 MX4J)您 可以利用 SOAP 或 Hessian 等协议,而不是简单的 HTTP 或 SSL 等, 如下例所示:spring-doc.cn

<bean id="serverConnector" class="org.springframework.jmx.support.ConnectorServerFactoryBean">
	<property name="objectName" value="connector:name=burlap"/>
	<property name="serviceUrl" value="service:jmx:burlap://localhost:9874"/>
</bean>

在前面的示例中,我们使用了 MX4J 3.0.0。查看官方 MX4J 文档了解更多信息。spring-doc.cn