我正在尝试连接到服务器上运行的远程jboss实例。我使用以下连接URL
服务:JMX:远程-JMX://90.214.64.170:9999
当我这样做时,我在控制台窗口中收到以下2个错误
选择不安全后我会看到这个
我在通过jconsole连接之前也进入了我的jboss服务器的bin目录并运行./jconsole.sh
,它将以下内容输出到命令行
CLASSPATH /usr/bin/java/jdk1.8.0_11/lib/jconsole.jar:/usr/bin/java/jdk1.8.0_11/lib/tools.jar:/var/opt/jboss/modules/system/layers/base/org/jboss/remoting-jmx/main/remoting-jmx-1.1.2.Final-redhat-1.jar:/var/opt/jboss/modules/system/layers/base/org/jboss/remoting3/main/jboss-remoting-3.2.18.GA-redhat-1.jar:/var/opt/jboss/modules/system/layers/base/org/jboss/logging/main/jboss-logging-3.1.2.GA-redhat-1.jar:/var/opt/jboss/modules/system/layers/base/org/jboss/xnio/main/xnio-api-3.0.7.GA-redhat-1.jar:/var/opt/jboss/modules/system/layers/base/org/jboss/xnio/nio/main/xnio-nio-3.0.7.GA-redhat-1.jar:/var/opt/jboss/modules/system/layers/base/org/jboss/sasl/main/jboss-sasl-1.0.3.Final-redhat-1.jar:/var/opt/jboss/modules/system/layers/base/org/jboss/marshalling/main/jboss-marshalling-1.4.2.Final-redhat-1.jar:/var/opt/jboss/modules/system/layers/base/org/jboss/marshalling/river/main/jboss-marshalling-river-1.4.2.Final-redhat-1.jar:/var/opt/jboss/modules/system/layers/base/org/jboss/as/cli/main/jboss-as-cli-7.3.0.Final-redhat-14.jar:/var/opt/jboss/modules/system/layers/base/org/jboss/staxmapper/main/staxmapper-1.1.0.Final-redhat-2.jar:/var/opt/jboss/modules/system/layers/base/org/jboss/as/protocol/main/jboss-as-protocol-7.3.0.Final-redhat-14.jar:/var/opt/jboss/modules/system/layers/base/org/jboss/dmr/main/jboss-dmr-1.2.0.Final-redhat-1.jar:/var/opt/jboss/modules/system/layers/base/org/jboss/as/controller-client/main/jboss-as-controller-client-7.3.0.Final-redhat-14.jar:/var/opt/jboss/modules/system/layers/base/org/jboss/threads/main/jboss-threads-2.1.1.Final-redhat-1.jar
我不确定我还能尝试什么(还打开了端口9999)才能让它工作,有没有人有任何建议或提示可能有助于解决这个问题?
由于
修改
将我的standalone.conf文件修改为此
#
# Specify options to pass to the Java VM.
#
if [ "x$JAVA_OPTS" = "x" ]; then
JAVA_OPTS="-Xms1303m -Xmx1303m -XX:MaxPermSize=256m -Djava.net.preferIPv4Stack=true"
JAVA_OPTS="$JAVA_OPTS -Djboss.modules.system.pkgs=$JBOSS_MODULES_SYSTEM_PKGS -Djava.awt.headless=true"
JAVA_OPTS="$JAVA_OPTS -Dcom.sun.management.jmxremote"
JAVA_OPTS="$JAVA_OPTS -Dcom.sun.management.jmxremote.port=9999"
JAVA_OPTS="$JAVA_OPTS -Dcom.sun.management.jmxremote.ssl=false"
JAVA_OPTS="$JAVA_OPTS -Dcom.sun.management.jmxremote.authenticate=false"
else
echo "JAVA_OPTS already set in environment; overriding default settings with values: $JAVA_OPTS"
fi
我仍然无法连接 - 与上面相同的错误
答案 0 :(得分:12)
按照下面提到的说明在JBoss中启用远程JMX监控
JBoss 4.2.3.GA
修改JBoss bin目录中可用的run.conf文件,并添加以下行 -
JAVA_OPTS="$JAVA_OPTS -Dcom.sun.management.jmxremote.port=<PORT>"
JAVA_OPTS="$JAVA_OPTS -Dcom.sun.management.jmxremote.authenticate=false"
JAVA_OPTS="$JAVA_OPTS -Dcom.sun.management.jmxremote.ssl=false"
JAVA_OPTS="$JAVA_OPTS -Djboss.platform.mbeanserver"
JAVA_OPTS="$JAVA_OPTS -Djavax.management.builder.initial=org.jboss.system.server.jmx.MBeanServerBuilderImpl"
JBoss 5.1.0.GA
由于JBoss中存在已在JBoss 6.0版本中修复的错误(https://issues.jboss.org/browse/JBAS-6185),因此无法在JBoss 5.1中配置JMX端口。
JBoss 6.1.0.Final
修改JBoss bin目录中可用的run.conf文件,并添加以下行 -
JAVA_OPTS="$JAVA_OPTS -Djava.util.logging.manager=org.jboss.logmanager.LogManager"
JAVA_ARGS="$JAVA_OPTS -Dorg.jboss.logging.Logger.pluginClass=org.jboss.logging.logmanager.LoggerPluginImpl"
JBOSS_CLASSPATH="../lib/jboss-logmanager.jar"
JAVA_OPTS="$JAVA_OPTS -Dcom.sun.management.jmxremote.port=<PORT>"
JAVA_OPTS="$JAVA_OPTS -Dcom.sun.management.jmxremote.authenticate=false"
JAVA_OPTS="$JAVA_OPTS -Dcom.sun.management.jmxremote.ssl=false"
JAVA_OPTS="$JAVA_OPTS -Djboss.platform.mbeanserver"
JAVA_OPTS="$JAVA_OPTS -Djavax.management.builder.initial=org.jboss.system.server.jmx.MBeanServerBuilderImpl"
JAVA_OPTS="$JAVA_OPTS -Djava.rmi.server.hostname=<IP_ADDRESS>"
JBoss 7.1.1.Final
修改JBoss bin目录中的standalone.conf文件,并添加以下行 -
JAVA_OPTS="$JAVA_OPTS -Dcom.sun.management.jmxremote.port=<PORT>"
JAVA_OPTS="$JAVA_OPTS -Dcom.sun.management.jmxremote.authenticate=false"
JAVA_OPTS="$JAVA_OPTS -Dcom.sun.management.jmxremote"
JAVA_OPTS="$JAVA_OPTS -Dcom.sun.management.jmxremote.ssl=false"
JAVA_OPTS="$JAVA_OPTS -Djboss.platform.mbeanserver"
JAVA_OPTS="$JAVA_OPTS -Djava.rmi.server.hostname=<IP_ADDRESS>"
JAVA_OPTS="$JAVA_OPTS -Djava.util.logging.manager=org.jboss.logmanager.LogManager -Xbootclasspath/p:../modules/org/jboss/logmanager/main/jboss-logmanager-1.2.2.GA.jar -Xbootclasspath/p:../modules/org/jboss/logmanager/log4j/main/jboss-logmanager-log4j-1.0.0.GA.jar -Xbootclasspath/p:../modules/org/apache/log4j/main/log4j-1.2.16.jar"
JAVA_OPTS="$JAVA_OPTS -Djboss.modules.system.pkgs=org.jboss.logmanager"
注意:根据您的要求进行修改。
参考:
https://community.jboss.org/wiki/JBossMBeansInJConsole
http://abh1sh3k.blogspot.in/2013/12/jmx-configuration-in-different-versions.html
答案 1 :(得分:5)
我找到了答案 - 至少是一个解决方案。
仔细阅读了针对EAP 6.3的新JBOSS发行说明here,我发现了以下内容;
恢复的ServiceMBean助手类org.jboss.as.system-jmx 已经引入了模块来恢复可用的辅助类 早期版本的JBoss EAP,可以帮助用户创建MBean。
我们所做的是部署一个新的独立实例 - 6.3的干净安装,然后遵循本指南;
https://planet.jboss.org/post/jmx_connections_to_jboss_as
我们不需要添加任何可选参数,不需要修改standalone.sh,也不需要修改standalone.xml。
我看到有人因为错误的答案而获得了5张选票 - 这是否因此获得赏金?!
答案 2 :(得分:5)
好的...这对我来说真的是一个问题,并且对于你知道如果你在不同的机器上放置JConsole和JBoss很重要, Java附带的JConsole不能工作 ..你必须在你有JConsole的机器上下载JBoss的副本,并在bin文件夹中查找 jconsole.bat 文件。
我从这里开始:http://www.java-redefined.com/2014/02/jboss-7-with-jconsole.html
答案 3 :(得分:0)
我相信远程连接你必须创建一个Application Realm用户(使用add-user.sh。我对这个问题是否会用于远程服务器连接或EJB远程用户的问题回答是,尽管我和#39 ;我不确定这是绝对必要的。)
然后使用这些凭据连接jconsole。
我对此的体验也与在域模式下运行的EAP 6.2.4的远程连接隔离开来。我只希望与独立服务器的远程连接是一样的。目前还不清楚你在这里使用的是什么。
我也改了它,所以我可以通过在CLI中发出这个命令来使用端口4447: /简档=公顷/子系统= JMX /远程连接器= JMX:添加(使用管理端点=假)
它并不适用于您的问题,因为您似乎正在使用JDK 8,但我认为需要JDK 7或更高版本(对于jconsole)。
希望这里有所帮助!
答案 4 :(得分:0)
JBoss 6.2.0 EAP
要将JConsole与JBoss 6.2 EAP一起使用,您必须启动它将一些JAR添加到类路径中。
在目录/jboss-eap-6.2/bin/client
中有一个README文件:
跑去JCONSOLE:
jconsole -J-Djava.class.path=<PATH TO jconsole.jar>;<PATH TO tools.jar>;<PATH TO jboss-cli-client.jar>
答案 5 :(得分:0)
对于版本6.1,请确保已将正确的portoffset添加到默认端口号,默认为9999,因此远程进程应该使用:
service:jmx:remoting-jmx://90.214.64.170:(offsetnumber+9999)
显然,这在版本6.2中得到了解决