在路上

 找回密码
 立即注册
在路上 站点首页 学习 查看内容

如何用JMX连接本地JVM上运行的Java程序

2017-2-16 13:16| 发布者: zhangjf| 查看: 948| 评论: 0

摘要: 问题: 我需要使用JMX连接本地JVM的java程序。换句话说,我想开发一个JMX的客户端来配置一个本地Java程序。 请不要推荐使用JConsole!JConsole不合适,因为JConsole是一个通用的JMX客户端,对主程序的性能存在负 ...
问题:

我需要使用JMX连接本地JVM的java程序。换句话说,我想开发一个JMX的客户端来配置一个本地Java程序。

请不要推荐使用JConsole!JConsole不合适,因为JConsole是一个通用的JMX客户端,对主程序的性能存在负面影响。 Oracle网站上有一个使用RMIConnector和“主机 : 端口号”为参数的例子,但是我不知道在什么地方设置JMX的端口号? JConsole可以选择PID来连接Java进程。但是在JMX的API中,我找不到任何方法是使用PID作为参数的。 回复:

我们使用一些类似下面的程序来连接JMX服务器。不过,需要在运行服务器时指定以下参数:

  1. -Dcom.sun.management.jmxremote
  2. -Dcom.sun.management.jmxremote.authenticate=false
  3. -Dcom.sun.management.jmxremote.port=1234
  4. -Dcom.sun.management.jmxremote.ssl=false
复制代码

为了绑定特定地址,你需要在增加下面的VM参数:

  1. -Djava.rmi.server.hostname=A.B.C.D
复制代码

这样,你就可以像下面的JMX客户端代码一样连接你的服务器了:

  1. String host = "localhost"; // or some A.B.C.D
  2. int port = 1234;
  3. String url = "service:jmx:rmi:///jndi/rmi://" + host + ":" + port + "/jmxrmi";
  4. JMXServiceURL serviceUrl = new JMXServiceURL(url);
  5. JMXConnector jmxConnector = JMXConnectorFactory.connect(serviceUrl, null);
  6. try {
  7. MBeanServerConnection mbeanConn = jmxConnector.getMBeanServerConnection();
  8. // now query to get the beans or whatever
  9. Set<ObjectName> beanSet = mbeanConn.queryNames(null, null);
  10. ...
  11. } finally {
  12. jmxConnector.close();
  13. }
复制代码

我们也可以不使用VM参数,代码本身可以通过编程在指定端口号发布。但是我想这个已经比你的需求更复杂了。

如果要根据PID来连接,据我现在所知,你需要使用Java 6以上的版本。我没使用过下面的代码,但是看起是可以正常工作的:

  1. List<VirtualMachineDescriptor> vms = VirtualMachine.list();
  2. for (VirtualMachineDescriptor desc : vms) {
  3. VirtualMachine vm;
  4. try {
  5. vm = VirtualMachine.attach(desc);
  6. } catch (AttachNotSupportedException e) {
  7. continue;
  8. }
  9. Properties props = vm.getAgentProperties();
  10. String connectorAddress =
  11. props.getProperty("com.sun.management.jmxremote.localConnectorAddress");
  12. if (connectorAddress == null) {
  13. continue;
  14. }
  15. JMXServiceURL url = new JMXServiceURL(connectorAddress);
  16. JMXConnector connector = JMXConnectorFactory.connect(url);
  17. try {
  18. MBeanServerConnection mbeanConn = connector.getMBeanServerConnection();
  19. Set<ObjectName> beanSet = mbeanConn.queryNames(null, null);
  20. ...
  21. } finally {
  22. jmxConnector.close();
  23. }
  24. }
复制代码

我已发布过一个新的SimpleJMX包,该包能帮助很简单的启动一个JMX服务,并向远程客户端发送beans。

  1. //创建一个新的服务器并监听8000端口
  2. JmxServer jmxServer = new JmxServer(8000);
  3. //启动服务器
  4. jmxServer.start();
  5. //注册下面定义的lookupCache对象
  6. jmxServer.register(lookupCache);
  7. jmxServer.register(someOtherObject);
  8. //停止服务
  9. jmxServer.stop();
复制代码

该包确实有一个客户端的接口,但是当前没有人一种机制是可以通过PID来查找进程的,只支持主机/端口的组合方式查找。

原文链接: stackoverflow 翻译: ImportNew.com - paddx
译文链接: http://www.importnew.com/15982.html

最新评论

小黑屋|在路上 ( 蜀ICP备15035742号-1 

;

GMT+8, 2025-5-7 01:11

Copyright 2015-2025 djqfx

返回顶部