利用VisualVm和JMX远程监控K8S里的Java进程

发布时间:2019-11-17 发布网站:脚本宝典
脚本宝典收集整理的这篇文章主要介绍了利用VisualVm和JMX远程监控K8S里的Java进程脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。

原文地址

利用VisualVm和JMX远程监控Java进程VisualVm利用SSL连接JMX的方法里介绍了如何使用VisualVm+JMX监控远程Java进程的方法。那么如何监控一个运行在K8S集群中的Java进程呢?其实大致方法也是类似的。

非SSL JMX连接

如果采用非SSL JMX连接,那么你只需要这么几步就可以让你本地的VisuaLVM连接到K8S集群里的Java进程了。

Step1 修改deployment.yaml,添加以下System Properties

-Dcom.sun.management.jmxremote -Dcom.sun.management.jmxremote.authenticate=false -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.port=1100 -Dcom.sun.management.jmxremote.rmi.port=1100 -Djava.rmi.server.hostname=localhost

注意,-Djava.rmi.server.hostname一定要设置成localhost

Step2 修改Deployment.yaML,添加Container Port

containers: - name: ...   image: ...   ports:   - containerPort: 1100     name: tcp-jmx

SteP3 部署Deployment

Step4 利用kubectl转发端口

kubectl -n <namespace> port-forward <pod-name> 1100

Step5 启动VisualVm,创建JMX连接localhost:1100

SSL JMX连接

启用SSL JMX连接,那么需要增加三个步骤,步骤就稍微复杂一些,假设你已经根据VisualVm利用SSL连接JMX的方法创建好了java-appvisualvm的keyStore和truststore。

Step1 创建一个Secret包含java-app.keystorejava-app.truststore

kubectl -n <namespace> create secret generic jmx-ssl    --from-file=java-app.keystore    --from-file=java-app.truststore

Step2 修改Deployment.yaml,把Secret挂载到容器内的/jmx-ssl目录下

  containers:  - name: ...    image: ...    volumemounts:    - name: jmx-ssl-vol      mountPath: /jmx-ssl  volumes:  - name: jmx-ssl-vol    secret:      secretName: jmx-ssl

Step3 修改Deployment.yaml,添加以下System PRoperties

-Dcom.sun.management.jmxremote -Dcom.sun.management.jmxremote.port=1100 -Dcom.sun.management.jmxremote.rmi.port=1100 -Dcom.sun.management.jmxremote.authenticate=false -Dcom.sun.management.jmxremote.ssl=true -Dcom.sun.management.jmxremote.registry.ssl=true -Dcom.sun.management.jmxremote.ssl.need.client.auth=true -Djavax.net.ssl.keyStore=/jmx-ssl/java-app.keystore -Djavax.net.ssl.keyStorePassword=<keystore password> -Djavax.net.ssl.trustStore=/jmx-ssl/java-app.truststore -Djavax.net.ssl.trustStorePassword=<truststore password> -Djava.rmi.server.hostname=localhost

注意,-Djava.rmi.server.hostname一定要设置成localhost

Step4 修改Deployment.yaml,添加Container Port

containers: - name: ...   image: ...   ports:   - containerPort: 1100     name: tcp-jmx   ...

Step5 部署Deployment

Step6 利用kubectl转发端口

kubectl -n <namespace> port-forward <pod-name> 1100

Step7 启动VisualVm,创建JMX连接localhost:1100

jvisualvm -J-Djavax.net.ssl.keyStore=<path to visualvm.keystore>    -J-Djavax.net.ssl.keyStorePassword=<visualvm.keystore的密码>    -J-Djavax.net.ssl.trustStore=<path to visualvm.truststore>    -J-Djavax.net.ssl.trustStorePassword=<visualvm.truststore的密码>

K8S样例配置文件

相关K8S样例配置文件在这里(用tomcat做的例子)。

脚本宝典总结

以上是脚本宝典为你收集整理的利用VisualVm和JMX远程监控K8S里的Java进程全部内容,希望文章能够帮你解决利用VisualVm和JMX远程监控K8S里的Java进程所遇到的问题。

如果觉得脚本宝典网站内容还不错,欢迎将脚本宝典推荐好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。