我应该使用JMX连接到localhost jvm上的Java程序。换句话说,我想开发一个JMX客户端以在localhost上配置Java程序。
不建议使用JConsole!JConsole不适合使用,因为它是通用JMX客户端,并且对主程序性能有负面影响。
甲骨文站点上的示例使用RMIConnector和host:port参数,但我不知道:应该在哪里设置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参数之外的特定端口,但这比我想的还要有用。
就连接“ by pid”而言,据我所知,您需要使用Java6从Java领域进行操作。我没有使用以下代码,但似乎可以正常工作。
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服务器和将bean发布到远程客户端变得很容易。
// create a new server listening on port 8000
JmxServer jmxServer = new JmxServer(8000);
// start our server
jmxServer.start();
// register our lookupCache object defined below
jmxServer.register(lookupCache);
jmxServer.register(someOtherObject);
// stop our server
jmxServer.stop();
它也有一个客户端接口,但是现在它没有任何机制可以通过PID查找进程-仅支持主机/端口组合(在6/2012中)。
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句