JMX

服务器响应指数异常,想用 JConsole 监控一下,就发现个 JMX 玩意,也就参考写一下笔记把



1. 什么是 JMX

JMX(Java Management Extensions,即Java管理扩展)是一个 Java 平台的管理和监控接口,是 JavaEE内嵌的一套标准的代理和服务,也就是说只要遵循这个接口标准,那么就可以管理和监控我们的应用程序


JVM 首先会将自身的各种资源注册到 JMX 中,所以我们能够监控到堆栈、内存、线程、类加载等数据。当然也可以将我们创建的对象也注册到 JMX 中进行管理和监控


开源库中也有更加通用的工具,比如 SpringBoot-Actuator,使用和配置起来更加简便





2. 结构

JMX


  • 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的方法,在控制台输出内容

JMX

JMX





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


上一篇:如何简化大量的 if…elif…else 代码?


下一篇:PowerShell:Get-CIMInstance Vs Get-WMIObject