JDK监控工具jvisualvm使用

一.所在目录

在安装的JDK的bin目录下

二.连接

1.本地连接

打开jvisualvm工具,不需要连接,它会自动添加本地所运行的java程序的进程

2.远程连接

1.右键点击远程,选择添加远程主机
在这里插入图片描述
2.填写主机IP地址,选中显示名称,点击确定按钮,添加成功
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
3.在linux系统上运行java程序需要加一些参数,所以执行命令为:

java -Dcom.sun.management.jmxremote.port=40124 -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false -Djava.rmi.server.hostname=10.2.3.4 -jar xxx.jar
-Dcom.sun.management.jmxremote.port=40124    //端口号,选取未被占用的端口
-Dcom.sun.management.jmxremote.ssl=false     //不要求ssl连接
-Dcom.sun.management.jmxremote.authenticate=false     //不使用密码验证
-Djava.rmi.server.hostname=10.2.3.4     //运行程序的主机ip
-jar xxx.jar     //运行java程序

4.java程序启动成功后,右键点击添加的远程连接, 选择添加JMX连接,填写上端口号,点击确定即可
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
提醒:连接的主机防火墙要关闭,不然会连接失败。

5.双击添加的进程就可以查看相关信息了

三.结果分析

以无限创建PreparedStatement为例

1.在循环里创建后,用完接着关闭

在这里插入图片描述在这里插入图片描述

2.在循环里创建后,最后在finally里关闭

在这里插入图片描述在这里插入图片描述

3.在循环里创建后,不关闭

在这里插入图片描述在这里插入图片描述

总结:

以程序运行时的堆内存使用情况来分析:第一种情况用完就关闭,曲线波动范围小,并且最高点较低;第二种情况最后关闭,波动范围较大,并且最高点较高;第三种情况不关闭,波动范围大,最高点较高。综上所得,每次用完都关闭,波动小,使用内存较少。

四.睡眠方法是否可以解决内存溢出问题

在这里插入图片描述在这里插入图片描述

总结:

死循环中加入睡眠方法,在短时间内不会出现内存溢出,上图可以看出程序跑了一个半小时,堆内存使用曲线走势是,缓慢上升然后降下来,然后继续缓慢上升,然后再降下来,但是看整体趋势是在很缓慢的上升,但是上升速度越来越快,所以最后结论是睡眠方法并不能解决内存溢出问题,只能延长程序运行的时间,推迟内存溢出的出现。
如果不加睡眠方法,不到一分钟就内存溢出,加上睡眠方法应该是几个小时才会内存溢出。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值