Дистанционный контроль с visualvm и JMX
Я хотел бы контролировать удаленно запущенное приложение java (spring boot) с помощью jvisualvm (или jconsole). При локальном запуске я вижу управляемые бобы как в jvisualvm, так и в jconsole. При удаленном запуске я не могу подключиться. Я попробовал его с несколькими различными процессами java (например, с spring xd). Поиск ответов здесь на SO и на Google не помог.
это мои JAVA_OPTS (на удаленном хосте):
$ echo $JAVA_OPTS
-Dcom.sun.management.jmxremote -Dcom.sun.management.jmxremote.port=9010 -Dcom.sun.management.jmxremote.local.only=false -Dcom.sun.management.jmxremote.authenticate=false -Djava.rmi.server.hostname=192.168.59.99
тогда я просто запускаю программу как следует (это для spring xd, Но я испытываю ту же проблему с другими программами java).
$ bin/xd/xd-singlenode
серверный процесс, похоже, подбирает параметры:
$ ps -ef | grep single
vagrant 22938 19917 99 06:38 pts/2 00:00:03 /usr/lib/jvm/java-8- oracle/jre/bin/java -Dcom.sun.management.jmxremote -Dcom.sun.management.jmxremote.port=9010 -Dcom.sun.management.jmxremote.local.only=false -Dcom.sun.management.jmxremote.authenticate=false -Djava.rmi.server.hostname=192.168.59.99 -Dspring.application.name=admin -Dlogging.config=file:/home/vagrant/spring-xd-1.1.0.RELEASE/xd/config///xd-singlenode-logger.properties -Dxd.home=/home/vagrant/spring-xd-1.1.0.RELEASE/xd -Dspring.config.location=file:/home/vagrant/spring-xd-1.1.0.RELEASE/xd/config// -Dxd.config.home=file:/home/vagrant/spring-xd-1.1.0.RELEASE/xd/config// -Dspring.config.name=servers,application -Dxd.module.config.location=file:/home/vagrant/spring-xd-1.1.0.RELEASE/xd/config//modules/ -Dxd.module.config.name=modules -classpath (...)
версия java на удаленном хосте (ubuntu linux vm):
$ java -version
java version "1.8.0_45"
Java(TM) SE Runtime Environment (build 1.8.0_45-b14)
Java HotSpot(TM) 64-Bit Server VM (build 25.45-b02, mixed mode)
версия java на локальном компьютере (Mac OS) немного отличается:
$ java -version
java version "1.8.0_40"
Java(TM) SE Runtime Environment (build 1.8.0_40-b25)
Java HotSpot(TM) 64-Bit Server VM (build 25.40-b25, mixed mode)
в jvisualvm я добавляю удаленное соединение следующим образом (пробовал как с ssl-соединением, так и без):
это сообщение об ошибке jvisualvm дает мне:
Я могу подключиться с локального хоста на удаленный с помощью команды telnet 192.168.59.99:9010
, когда удаленный процесс запущен - так что это не кажется проблемой брандмауэра.
любая помощь будет высоко ценится.
1 ответов
пожалуйста, используйте следующие параметры JVM :
-Dcom.sun.management.jmxremote -Dcom.sun.management.jmxremote.port=9010 -Dcom.sun.management.jmxremote.authenticate=false -Dcom.sun.management.jmxremote.ssl=false -Djava.rmi.server.hostname=192.168.59.99
в Jconsole используйте следующее Для подключения:
service:jmx:rmi:///jndi/rmi://192.168.59.99:9010/jmxrmi