如何用JMX連線本地JVM上執行的Java程式
問題:
我需要使用JMX連線本地JVM的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引數:
-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來查詢程式的,只支援主機/埠的組合方式查詢。
相關文章
- 如何用JMX連線本地JVM的Java程式JVMJava
- 用JMX怎樣連線本地JVM上執行的Java程式JVMJava
- 如何用Java連線Aurora MySQLJavaMySql
- java連線oracle執行sql語句JavaOracleSQL
- Jconsole與Jmx 分析JVM狀況(上)JVM
- banq請問如何用java程式呼叫windows的執行命令JavaWindows
- 怎麼在 JMX 中使用連線池
- 深入理解JVM(③)執行緒與Java的執行緒JVM執行緒Java
- 關於在執行java連線MongoDB時遇到的連線超時問題JavaMongoDB
- Java連線mysql的程式JavaMySql
- jvm-執行時資料區(程式計數器、Java虛擬機器棧、本地方法棧)JVMJava虛擬機
- jProfiler遠端連線Linux監控jvm、tomcat執行狀態LinuxJVMTomcat
- Oracle中表連線的執行原理Oracle
- 表連線的執行步驟
- Java呼叫本地可執行程式Java行程
- 瞭解JDK、JRE、JVM及Java程式的編譯與執行JDKJVMJava編譯
- 圖解JVM記憶體模型及JAVA程式執行原理圖解JVM記憶體模型Java
- 【JVM原始碼解析】虛擬機器解釋執行Java方法(上)JVM原始碼虛擬機Java
- Finalshell 連線本地虛擬機器上的 ManjaroLinux虛擬機JARLinux
- 使用JMX Exporter監控Rainbond上的Java應用ExportAIJava
- JVM(一)——Java 執行時的資料區域JVMJava
- Java-JVM-執行時資料區JavaJVM
- 1.6.3.3. 本地連線和安全的遠端連線
- kettle連線本地MYSQLMySql
- 理解Java程式的執行Java
- Java執行緒(篇外篇):執行緒本地變數ThreadLocalJava執行緒變數thread
- 從Java到JVM到OS執行緒睡眠JavaJVM執行緒
- 教你如何用node連線redisRedis
- JVM中的執行緒行為JVM執行緒
- 如何用iPad執行Python程式碼?iPadPython
- JVM程式用一個主執行緒來執行main()方法JVM執行緒AI
- vnc連線本地,vnc連線本地用的什麼軟體?3款好用推薦VNC
- java本地連線遠端Hbase可是返回zookeeper的地址是localhostJavalocalhost
- 刪除本地連線2的方法
- 本地無法連線Mysql的原因MySql
- 伺服器上的程式碼怎麼可以在本地測試執行Debug伺服器
- 怎樣用好本地連線
- jvm入門及理解(三)——執行時資料區(程式計數器+本地方法棧)JVM