【JAVA教程】如何用JMX串連本地JVM上啟動並執行Java程式-潭州JAVA

來源:互聯網
上載者:User

標籤:jmx   用戶端   beans   java   

需解決的問題:

   想開發一個JMX的用戶端來配置一個本地Java程式。具體要求如下:


請不要推薦使用JConsole!JConsole不合適,因為JConsole是一個通用的JMX用戶端,對主程式的效能存在負面影響。

Oracle網站上有一個使用RMIConnector和“主機 : 連接埠號碼”為參數的例子,但是我不知道在什麼地方設定JMX的連接埠號碼?

JConsole可以選擇PID來串連Java進程。但是在JMX的API中,我找不到任何方法是使用PID作為參數的。

解答:

我們使用一些類似下面的程式來串連JMX伺服器。不過,需要在運行伺服器時指定以下參數:


-Dcom.sun.management.jmxremote

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

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

-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提出。


本文出自 “JAVA學習視頻教程” 部落格,請務必保留此出處http://10239772.blog.51cto.com/10229772/1659718

【JAVA教程】如何用JMX串連本地JVM上啟動並執行Java程式-潭州JAVA

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.