How Tomcat works 18: JMX管理
1. Tomcat中的JMX概述
(1)概述
对于一个可以被管理的Java对象,我们需要创建另一个对象MBean或Managed Bean。org.apache.catalina.mbeans包中有:ConnectorMBean, StandardEngineMBean, StandardHostMBean, StandardContextMBean。
一个MBean暴露出他所管理的Java Objects的属性和方法(可被调用的)。一旦有了MBean类,需要实例化它并把被管理的对象和自己注册到Mbean Server。
(2)四种类型
Standard,Dynamic,Open,model
(3)架构上三层
Agent, instrumentation,distributed service
2. MBeanServer
Java.management.MBeanServer接口代表了Mbean Server。可以使用MBeanServerFactory类来创建MbeanServer的实例。使用RegisterMBean()来注册MBean。
public ObjectInstance registerMBean(java.lang.Object object, ObjectName name) throws InstanceAlreadyExistsException, MBeanRegistrationException, NotCompliantMBeanException
可以通过 queryNames来查询MBean
public java.util.Set queryNames(ObjectName name, QueryExp query)
3. 简单的JMX实现
(1)MBean接口
public interface HelloMBean {
public void sayHello();
}
(2)Bean实现
public class Hello implements HelloMBean {
@Override
public void sayHello() {
System.out.println("hello, world");
}
}
(3)实例化MBeanServer, 注册Mbean
public class TestJmx {
public static void main(String[] args) throws Exception, MBeanRegistrationException, NotCompliantMBeanException {
MBeanServer mBeanServer = ManagementFactory.getPlatformMBeanServer();
ObjectName name = new ObjectName("com.cisco.tomcat.jmx:type=Hello");
Hello mBean = new Hello();
mBeanServer.registerMBean(mBean, name);
System.out.println("Waiting forever...");
Thread.sleep(Long.MAX_VALUE);
}
}
(4)运行这个main线程,然后打开jconsole连接到该线程
选中需要连接的pid
Click sayHello(), hello中的代码就被调用成功了