当我们通过jvisualvm来连接VM的时候,我们需要在运行进程所在的脚本中,追加以下配置:
JAVA_OPTS="-XX:MaxPermSize=128m $OUR_JAVA_OPTS
-Dcom.sun.management.jmxremote
-Dcom.sun.management.jmxremote.port=10207 // 端口号,可以自定义
-Dcom.sun.management.jmxremote.authenticate=false
-Dcom.sun.management.jmxremote.ssl=false"
比如说,我们在本地中查看VM启动spark shell时,通过jvisualvm就可以监控Spark的进程了(上述配置在spark-class文件中配置,因为spark shell脚本最后调用的事spark-class脚本,spark-class脚本中有一个调用语句:exec "$RUNNER" -cp "$CLASSPATH" $JAVA_OPTS "$@")。
但是,我们完成上述操作后,遇到了一个小错误:
注:图是网上找的,但是,错误情况一样的。
出现这个原因一般有两个问题造成。
1.防火墙是否关闭。
2.上述的配置没有生效。
看了下,防火墙是关闭的。那就剩下了第二种可能,配置没有生效。当时的配置文件如下图所示:
错误很明显了,JAVA_OPTS放在了exec执行语句的后面了。由于shell是一个解释性语言,我们配置的JAVA_OPTS并不能够生效,我们只需要把配置放在exec的上方位置就好:
这样我们就可以通过jvisualvm来连接远程主机监控Java进程的状况了。