【JAVA教程】如何用JMX鏈接本地JVM上運行的Java程序-潭州JAVA

需解決的問題:java

   想開發一個JMX的客戶端來配置一個本地Java程序。具體要求以下:編程


請不要推薦使用JConsole!JConsole不合適,由於JConsole是一個通用的JMX客戶端,對主程序的性能存在負面影響。服務器

Oracle網站上有一個使用RMIConnector和「主機 : 端口號」爲參數的例子,可是我不知道在什麼地方設置JMX的端口號?ide

JConsole能夠選擇PID來鏈接Java進程。可是在JMX的API中,我找不到任何方法是使用PID做爲參數的。性能

解答:網站

咱們使用一些相似下面的程序來鏈接JMX服務器。不過,須要在運行服務器時指定如下參數:url


-Dcom.sun.management.jmxremotespa

-Dcom.sun.management.jmxremote.authenticate=falseorm

-Dcom.sun.management.jmxremote.port=1234server

-Dcom.sun.management.jmxremote.ssl=false

爲了綁定特定地址,你須要在增長下面的VM參數:


1-Djava.rmi.server.hostname=A.B.C.D

這樣,你就能夠像下面的JMX客戶端代碼同樣鏈接你的服務器了:



String host = "localhost";  // or some A.B.C.D

int port = 1234;

String url = "service:jmx:rmi:///jndi/rmi://" + host + ":" + port + "/jmxrmi";

JMXServiceURL serviceUrl = new JMXServiceURL(url);

JMXConnector jmxConnector = JMXConnectorFactory.connect(serviceUrl, null);

try {

   MBeanServerConnection mbeanConn = jmxConnector.getMBeanServerConnection();

   // now query to get the beans or whatever

   Set<ObjectName> beanSet = mbeanConn.queryNames(null, null);

   ...

} finally {

   jmxConnector.close();

}

咱們也能夠不使用VM參數,代碼自己能夠經過編程在指定端口號發佈。可是我想這個已經比你的需求更復雜了。


若是要根據PID來鏈接,據我如今所知,你須要使用Java 6以上的版本。我沒使用過下面的代碼,可是看起是能夠正常工做的:



List<VirtualMachineDescriptor> vms = VirtualMachine.list();

for (VirtualMachineDescriptor desc : vms) {

    VirtualMachine vm;

    try {

        vm = VirtualMachine.attach(desc);

    } catch (AttachNotSupportedException e) {

        continue;

    }

    Properties props = vm.getAgentProperties();

    String connectorAddress =

        props.getProperty("com.sun.management.jmxremote.localConnectorAddress");

    if (connectorAddress == null) {

        continue;

    }

    JMXServiceURL url = new JMXServiceURL(connectorAddress);

    JMXConnector connector = JMXConnectorFactory.connect(url);

    try {

        MBeanServerConnection mbeanConn = connector.getMBeanServerConnection();

        Set<ObjectName> beanSet = mbeanConn.queryNames(null, null);

        ...

    } finally {

        jmxConnector.close();

    }

}

我已發佈過一個新的SimpleJMX包,該包能幫助很簡單的啓動一個JMX服務,並向遠程客戶端發送beans。


//建立一個新的服務器並監聽8000端口

JmxServer jmxServer = new JmxServer(8000);

//啓動服務器

jmxServer.start();

//註冊下面定義的lookupCache對象

jmxServer.register(lookupCache);

jmxServer.register(someOtherObject);

//中止服務

jmxServer.stop();

該包確實有一個客戶端的接口,可是當前沒有人一種機制是能夠經過PID來查找進程的,只支持主機/端口的組合方式查找。


PS:若有什麼問題,請直接在羣457036818提出。

相關文章
相關標籤/搜索