服务器响应指数异常,想用 JConsole 监控一下,就发现个 JMX 玩意,也就参考写一下笔记把
1. 什么是 JMX
JMX(Java Management Extensions,即Java管理扩展)是一个 Java 平台的管理和监控接口,是 JavaEE内嵌的一套标准的代理和服务,也就是说只要遵循这个接口标准,那么就可以管理和监控我们的应用程序
JVM 首先会将自身的各种资源注册到 JMX 中,所以我们能够监控到堆栈、内存、线程、类加载等数据。当然也可以将我们创建的对象也注册到 JMX 中进行管理和监控
开源库中也有更加通用的工具,比如 SpringBoot-Actuator,使用和配置起来更加简便
2. 结构
- MBean:ManagedBean,被管理的Bean对象,是遵循接口规范的对象
- MBeanServer:管理 MBean 对象
- Connector、Adaptor:对外提供访问 JMX 的接口,使用 RMI、HTTP
3. 使用
MBean分为好几种,下面只是简单介绍,因为更加全面监控有 SpringBoot-Actuator
3.1 MBean接口
必须以实现类为前缀 + MBean
public interface HelloMBean {
public void helloWorld();
public void saySomething(String something);
}
3.2 实现类
public class Hello implements HelloMBean {
@Override
public void helloWorld() {
System.out.println("Hello JMX");
}
@Override
public void saySomething(String something) {
System.out.println(something);
}
}
3.3 管理类
public class MBeanManager {
public static void main(String[] args) throws Exception {
// 将MBean注册到管理器
MBeanServer mBeanServer = ManagementFactory.getPlatformMBeanServer();
ObjectName helloName = new ObjectName("jmxBean:name=hello");
mBeanServer.registerMBean(new Hello(), helloName);
// 让当前程序继续运行,以便监测
Thread.sleep(60 * 60);
}
}
3.4 JConsole监测
JConsole本地访问不需要任何配置,直接选择启动类就可进入
点击方法名可以调用MBean的方法,在控制台输出内容
4. JConsole 远程连接
服务器上启动 jar 包时要加上的启动参数,JConsole是使用 rmi 远程过程调用的,所以得填写 rmi.server.hostname
java
-Djava.rmi.server.hostname=127.0.0.1 // 填写服务器地址,也就是部署 jar 的地址
-Dcom.sun.management.jmxremote=true // 开启远程Jmx
-Dcom.sun.management.jmxremote.port=12345 // 对外开放监听断开
-Dcom.sun.management.jmxremote.ssl=false // 不使用用ssl连接
-Dcom.sun.management.jmxremote.authenticate=false // 不开启认证
-jar jmx-0.0.1-SNAPSHOT.jar