jdk 内存泄露调试流程
来源:互联网 发布:网络优化工作图片 编辑:程序博客网 时间:2024/06/05 12:03
今天要处理项目下的一个内存泄露的问题。使用了jprobe 工具,在测试环境反复调试不能发现问题的原因。最后使用jdk自带的jps jmap jstat 等工具顺利的查找到了内存泄露的原因。下面对jdk自带的jps jmap jstat工具总结介绍一下,希望以后同道中人google一下,找到这篇文章对大家有所帮助。尽量介绍的简明扼要,如果需要最详细的参考请翻阅jdk doc tools部分,如果有什么疑问请留言。
jps:
相当于linux下的ps,列出所有java相关线程的pid等信息
example:
[tdwiki@installed-host-eth0 ~]$ jps
18861 Bootstrap
1418 Jps
jmap:
显示java进程内存使用的相关信息
jmap pid 打印内存使用的摘要信息
jmap -histopid >mem.txt 打印比较简单的各个有多少个对象占了多少内存的信息,一般重定向的文件
jmap -dump:format=b,file= mem.dat pid 将内存使用的详细情况输出到mem.dat 文件
用jhat命令可以参看 jhat -port 7000 mem.dat
在浏览器中访问:http://10.5.22.65:7000/ 查看详细信息
jstat:
显示java虚拟机的一些统计信息
jstat -选项 pid 间隔显示时间显示次数
jstat -gc 18861 250 10
jstat -gccapacity 18861 250 10
jstat -gcnew 18861 250 10
jstat -gcnewcapacity 18861 250 10
jstat -gcold 18861 250 10
我的调试流程
内存泄漏一般都是有一定特征的,任何代码和数据都要占用内存,我简单总结内存泄漏的特征是内存占用不可控制,GC不可回收。我追踪内存使用量的曲线发现一些特征,在估计虚拟机即将崩溃时,使用 jmap -histopid >mem.txt 发现相关内存泄漏的对象占用非常打比例的内存空间,然后很容易猜测问题大概的位置,一下子就解决了。
- jdk 内存泄露调试流程
- 内存泄露调试
- VC调试内存泄露
- [DEBUG]内存泄露调试
- android 内存泄露调试
- 内存泄露的调试
- ios 内存泄露调试
- 调试内存泄露
- 内存泄露调试
- android 内存泄露调试
- 内存泄露调试
- Android内存泄露调试
- 内存泄露及调试
- CRT调试内存泄露
- opencv调试-内存泄露
- 内存泄露如何调试
- 内存泄露调试技巧(转)
- 使用HookLogger调试内存泄露
- linq 分组与统计 , not in/in功能
- 如何防止网页篡改系统技术的比较
- 隐式挖掘网站用户行为
- 小年快乐
- java获取域控下账号例子介绍ldap中概念
- jdk 内存泄露调试流程
- 前端工程师,所做,所想
- 美女时钟
- Fedora12 安装nvidia显卡驱动
- Launcher页面缓存.
- 为Ubuntu Server 添加硬盘
- [iPhone开发之控件的使用]UILabel的各种属性与方法的使用
- 新开帖子,以后在这儿混了!
- jQuery技巧总结 一