文档章节

JVM内存泄漏分析

孤鹜壑拽
 孤鹜壑拽
发布于 2015/08/26 10:28
字数 1158
阅读 103
收藏 0
点赞 0
评论 0

Top:

  f或者F 从当前显示中添加或者删除项目。
  o或者O 改变显示项目的顺序。
  l 切换显示平均负载和启动时间信息。
  m 切换显示内存信息。
  t 切换显示进程和CPU状态信息。
  c 切换显示命令名称和完整命令行。
  M 根据驻留内存大小进行排序。
  P 根据CPU使用百分比大小进行排序。
  T 根据时间/累计时间进行排序。

1、使用top命令,然后按c键,根据command的详细信息找出对应的java进程PID(ps、jps等方法也是OK的,方法可谓五花八门了),这里是2965;

2、top -p 2965,然后再按H(H是显示当前进程中的各线程),找到占cpu为100%左右的某线程(线程的PID为:2970)

3、将2970转16进制:B9A(快捷键win+r-->输入calc-->使用程序员计算器)

4、使用jstack -l 2965 | grep B9A找到当前线程,结果是:"Concurrent Mark-Sweep GC Thread" prio=10 tid=0x0000000053293800 nid=0x*** runnable 

5、而Concurrent Mark-Sweep GC Thread,是JVM的标记清除线程,可见GC太频繁,由于JVM中根据对象的存活周期的不同将内存划分为几块。把java堆分为新生代和老年代,根据各个年代的特点采用适当的收集算法。在新生代,每次垃圾收集时都发现有大批对象死去,只有少量幸存者,选用复制算法从from区到to区,只需要付出少量存活对象的复制成本就可以完成收集。而老年代中因为对象存活率高、并没有额外空间对他进行分配担保,就使用“标记-整理”算法进行回收,本次的内存漏问题主要发生在老龄代。

6、为了确定一下以上推测,再使用 jmap -heap 2965(注意:jmap不是运行分析工具,在生成结果时JVM可能会挂起,因此当生成统计结果时需要确认这种暂停对程序是可接受的,查看得老龄区占用内存已达99.99%(而老龄区的内存设置为: capacity = 2147483648 (2048.0MB));使用jmap -dump:format=b,file=dump.65 2965将内存dump成文件,将内存文件拿下来分析;

(可以不拿下来,直同样直接可以在服务器上使用jhat对dump文件分析,jhat默认会打开7000端口的web服务;并具如果dump文件过大,jhat需要使用的xmx参数也需要注意设置,否则OOM;jhat -J-mx4G -port 8080 D:\klive\midea\wspace\document\data\dump.65,但注意端口是否开放,是否冲突,机器是否够内存,详细分析过程不写了)

为了使结果更明显借用第三方工具:

7、下载memory analyzer tool工具进行dump文件分析,由于本人使的是intelij idea,而这个idea没有相对应的MAT插件,就懒得下载mat对应的eclipse的插件而是下载具有能独立运行的mat版本,具体地址是http://www.eclipse.org/mat/downloads.php,具体的eclipse插件可参考:http://blog.csdn.net/yanghongchang_/article/details/7711911

8、由于dump下来的文件大约3.2G,而想下载到工作的电脑上,这个是文件是大了点,使用tar -czf dum.tar.gz dump.65命令进行压缩,(加z是tar调用gzip进行压缩),具体的压缩命令,请参考:http://www.jb51.net/LINUXjishu/43356.html结果为600多M,虽然还很大,但却小了很多。

9、由于dump文件过大,所要以需要修改MAT启动的xmx参数:到mat安装的根目录下找到:MemoryAnalyzer.ini,修改-Xmx的值4096m;

10、启动mat,加载dump文件进行结果分析,不看不知道,一看挺恐怖javax.crypto.SunJCE_b这个类竟然占了2.1G内存;

结果一目了然:

org.bouncycastle.jce.provider.BouncyCastleProvider()的实例,一直回收不了,快撑爆了2G的老龄区;

后来分析知道的这个是用户解密的代码问题。检查common包的RSAUtil类,结果也是一目了然,这代码估计也是copy网上的然后没仔细检查一下,二话没说地使用了。

总结:这问题告诉我们这种结果不是我们想要;

备注:更详细的MAT分析:http://seanhe.iteye.com/blog/898277


© 著作权归作者所有

共有 人打赏支持
孤鹜壑拽
粉丝 1
博文 1
码字总数 1158
作品 0
广州
升级到JDK9的一个BUG,你了解吗

概述 前几天在一个群里看到一个朋友发了一个demo,说是JDK的bug,昨天在JVM的一个群里又有朋友发了,觉得挺有意思,分享给大家,希望大家升级JDK的版本的时候注意下是否存在这样的代码,如果...

你假笨 ⋅ 06/06 ⋅ 0

LINUX类主机JAVA应用程序占用CPU、内存过高分析手段

转载声明:本文为DBA+社群原创文章,转载必须连同本订阅号二维码全文转载,并注明作者名字及来源:DBA+社群(dbaplus)。 做为一个IT运维人员,通常在运维过程中会遇到各种各样的问题,系统问...

丁启良 ⋅ 2015/12/04 ⋅ 0

JVM第一篇:一个Java内存泄漏的排查案例

最近在看《深入理解Java虚拟机:JVM高级特性与最佳实践》(第二版)这本书,理论+实践结合,深入浅出,强烈推荐给大家。 这两天在“小怪的java群”里面也对JVM内容进行了一个讨论,讨论的内容...

小怪聊职场 ⋅ 05/31 ⋅ 0

加强Docker容器与Java 10集成

很多运行在Java虚拟机(JVM)中的应用,包括数据服务如Apache Spark和Kafka以及传统企业应用,都运行在容器中。最近,运行在容器里的JVM出现了由于内存和CPU资源限制和使用率导致性能损失问题...

java高级架构牛人 ⋅ 06/04 ⋅ 0

JVM性能调优实践——JVM篇

前言 在遇到实际性能问题时,除了关注系统性能指标。还要结合应用程序的系统的日志、堆栈信息、GClog、threaddump等数据进行问题分析和定位。关于性能指标分析可以参考前一篇JVM性能调优实践...

lijingyao8206 ⋅ 05/24 ⋅ 0

Metaspace溢出排查过程

庞彤彤 2014年8月加入去哪儿,目前就职于大住宿事业部,主要负责交易运营相关内容。 一、问题 线上的 task 服务出现报警,没有服务者,发现有的机器突然下线了。 第一次出现问题时,发现服务...

Qunar技术沙龙 ⋅ 06/12 ⋅ 0

Java堆和栈的区别,JVM的堆和栈的介绍

一、Java的堆内存和栈内存 Java把内存划分成两种:一种是堆内存,一种是栈内存。 堆:主要用于存储实例化的对象,数组。由JVM动态分配内存空间。一个JVM只有一个堆内存,线程是可以共享数据的...

光明辉煌 ⋅ 05/21 ⋅ 0

对象和数组并不是都在堆上分配内存的。

前段时间,给星球的球友们专门码了一篇文章《深入分析Java的编译原理》,其中深入的介绍了Java中的javac编译和JIT编译的区别及原理。并在文中提到:JIT编译除了具有缓存的功能外,还会对代码...

⋅ 05/13 ⋅ 0

一篇简单易懂的原理文章,让你把JVM玩弄与手掌之中

jvm原理 Java虚拟机是整个java平台的基石,是java技术实现硬件无关和操作系统无关的关键环节,是java语言生成极小体积的编译代码的运行平台,是保护用户机器免受恶意代码侵袭的保护屏障。JVM...

烂猪皮 ⋅ 05/08 ⋅ 0

Android Bitmap变迁与原理解析(4.x-8.x)

App开发不可避免的要和图片打交道,由于其占用内存非常大,管理不当很容易导致内存不足,最后OOM,图片的背后其实是Bitmap,它是Android中最能吃内存的对象之一,也是很多OOM的元凶,不过,在...

看书的小蜗牛 ⋅ 05/22 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

mysql in action / alter table

change character set ALTER SCHEMA `employees` DEFAULT CHARACTER SET utf8mb4 DEFAULT COLLATE utf8mb4_general_ci ;ALTER TABLE `employees`.`t2` CHARACTER SET = utf8mb4 , COLLAT......

qwfys ⋅ 今天 ⋅ 0

Java 开发者不容错过的 12 种高效工具

Java 开发者常常都会想办法如何更快地编写 Java 代码,让编程变得更加轻松。目前,市面上涌现出越来越多的高效编程工具。所以,以下总结了一系列工具列表,其中包含了大多数开发人员已经使用...

jason_kiss ⋅ 昨天 ⋅ 0

Linux下php访问远程ms sqlserver

1、安装freetds(略,安装在/opt/local/freetds 下) 2、cd /path/to/php-5.6.36/ 进入PHP源码目录 3、cd ext/mssql进入MSSQL模块源码目录 4、/opt/php/bin/phpize生成编译配置文件 5、 . ./...

wangxuwei ⋅ 昨天 ⋅ 0

如何成为技术专家

文章来源于 -- 时间的朋友 拥有良好的心态。首先要有空杯心态,用欣赏的眼光发现并学习别人的长处,包括但不限于工具的使用,工作方法,解决问题以及规划未来的能力等。向别人学习的同时要注...

长安一梦 ⋅ 昨天 ⋅ 0

Linux vmstat命令实战详解

vmstat命令是最常见的Linux/Unix监控工具,可以展现给定时间间隔的服务器的状态值,包括服务器的CPU使用率,内存使用,虚拟内存交换情况,IO读写情况。这个命令是我查看Linux/Unix最喜爱的命令...

刘祖鹏 ⋅ 昨天 ⋅ 0

MySQL

查看表相关命令 - 查看表结构    desc 表名- 查看生成表的SQL    show create table 表名- 查看索引    show index from  表名 使用索引和不使用索引 由于索引是专门用于加...

stars永恒 ⋅ 昨天 ⋅ 0

easyui学习笔记

EasyUI常用控件禁用方法 combobox $("#id").combobox({ disabled: true }); ----- $("#id").combobox({ disabled: false}); validatebox $("#id").attr("readonly", true); ----- $("#id").r......

miaojiangmin ⋅ 昨天 ⋅ 0

金山WPS发布了Linux WPS Office

导读 近日,金山WPS发布了Linux WPS Office中文社区版新版本,支持大部分主流Linux系统,功能更加完善,兼容性、稳定性大幅度提升。本次更新WPS将首次在Linux提供专业办公文件云存储服务,实...

问题终结者 ⋅ 昨天 ⋅ 0

springboot2输出metrics到influxdb

序 本文主要研究一下如何将springboot2的metrics输出到influxdb maven <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-bo......

go4it ⋅ 昨天 ⋅ 0

微信小程序 - 选择图片显示操作菜单

之前我分享过选择图片这个文章,但是我在实际开发测试使用中发现一个问题在使用 wx.chooseImage 选择照片显示出第一格是拍照,后面是相册里的图片。这种实现之前说过了,效果如下。 但是你从...

hello_hp ⋅ 昨天 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部