在java开发的过程中,有时候开发人员会遇到java内存泄露的问题,很多新手java人员遇到java内存泄露很是头疼,毕竟是没有实战经验的,所以这时候要是能够监控到就好了,那java内存泄露怎么监控?接下来我们就来给大家讲解一下这方面的内容。
进行java内容泄露监控,我们可以使用到一下几个命令:
1、jstack (linux下特有)
可以观察到jvm中当前所有线程的运行情况和线程当前状态
jstack 2083
输出内容如下:
2、jmap (linux下特有,也是很常用的一个命令)
观察运行中的jvm物理内存的占用情况。
参数如下:
-heap:打印jvm heap的情况-histo: 打印jvm heap的直方图。其输出信息包括类名,对象数量,对象占用大小。-histo:live : 同上,但是只答应存活对象的情况-permstat: 打印permanent generation heap情况
3、jstat
这是jdk命令中比较重要,也是相当实用的一个命令,可以观察到classloader,compiler,gc相关信息
具体参数如下:
class:统计class loader行为信息
compile:统计编译行为信息
gc:统计jdk gc时heap信息
gccapacity:统计不同的generations(不知道怎么翻译好,包括新生区,老年区,permanent区)相应的heap容量情况
gccause:统计gc的情况,(同-gcutil)和引起gc的事件
gcnew:统计gc时,新生代的情况
gcnewcapacity:统计gc时,新生代heap容量
gcold:统计gc时,老年区的情况
gcoldcapacity:统计gc时,老年区heap容量
gcpermcapacity:统计gc时,permanent区heap容量
gcutil:统计gc时,heap情况
printcompilation:不知道干什么的,一直没用过。
一般比较常用的几个参数是:
jstat -class 2083 1000 10 (每隔1秒监控一次,一共做10次)
参数解释:
Options — 选项,我们一般使用 -gcutil 查看gc 情况
vmid — VM 的进程号,即当前运行的java 进程号
interval– 间隔时间,单位为秒或者毫秒
count — 打印次数,如果缺省则打印无数次
S0 — Heap 上的 Survivor space 0 区已使用空间的百分比
S1 — Heap 上的 Survivor space 1 区已使用空间的百分比
E — Heap 上的 Eden space 区已使用空间的百分比
O — Heap 上的 Old space 区已使用空间的百分比
P — Perm space 区已使用空间的百分比
YGC — 从应用程序启动到采样时发生 Young GC 的次数
YGCT– 从应用程序启动到采样时 Young GC 所用的时间( 单位秒 )
FGC — 从应用程序启动到采样时发生 Full GC 的次数
FGCT– 从应用程序启动到采样时 Full GC 所用的时间( 单位秒 )
GCT — 从应用程序启动到采样时用于垃圾回收的总时间( 单位秒)
java内存泄露如何解决?
1.尽量减少使用静态变量,或者使用完及时赋值为 null。
2.明确内存对象的有效作用域,尽量缩小对象的作用域,能用局部变量处理的不用成员变量,因为局部变量弹栈会自动回收;
3.减少长生命周期的对象持有短生命周期的引用;
4.使用StringBuilder和StringBuffer进行字符串连接,Sting和StringBuilder以及StringBuffer等都可以代表字符串,其中String字符串代表的是不可变的字符串,后两者表示可变的字符串。如果使用多个String对象进行字符串连接运算,在运行时可能产生大量临时字符串,这些字符串会保存在内存中从而导致程序性能下降。
5.对于不需要使用的对象手动设置null值,不管GC何时会开始清理,我们都应及时的将无用的对象标记为可被清理的对象;
6.各种连接(数据库连接,网络连接,IO连接)操作,务必显示调用close关闭。
其实遇到java内存泄露的时候,开发人员不必慌张,只要我们找到泄露的原因然后再做出解决方法就可以了,当然我们也可以监控,这样就能够减少java内存泄露发生!最后大家如果想要了解更多java常见问答知识,敬请关注奇Q工具网。
推荐阅读: