How to use Eclipse Memory Analyzer to analyze JVM Memeory Issue

How to use Eclipse Memory Analyzer to analyze JVM Memeory Issue - 3 of Series "Inside JVM"
2009-12-03 15:10

This article will have a simple introduction on new tool – Eclipse Memory Analyzer (previously called SAP memory analyzer) and how to use this tool to find some interesting memory issues.

1. Install Memory Analyzer into Your Eclipse

  1. Start the Update Manage via Help → Software Updates…
  2. Choose the tab Available Software and add the Memory Analyzer Update site: http://download.eclipse.org/technology/mat/0.7/update-site/
  3. Pick the Memory Analyzer feature. And click “Install” button to install it.
  4. Accept the license and restart Eclipse

2. Getting a Heap Dump from Sun Virtual Machines

The Memory Analyzer can work with HPROF binary formatted heap dumps. Those heap dumps are written by Sun HotSpot and any VM derived from HotSpot. Depending on your scenario, your OS platform and your JDK version, you have different options to acquire a heap dump.

Vendor / Release-XX:+HeapDumpOnOutOfMemoryError writes heap dump on OutOfMemoryError-XX:+HeapDumpOnCtrlBreak writes heap dump together with thread dump on CTRL+BREAKSun JMap: jmap.exe -dump:format=b,file=HeapDump.hprofSun JConsole: Launch jconsole.exe and invoke operation dumpHeap() on HotSpotDiagnostic MBean
1.4.2_12YesYesNoNo
1.5.0_07YesNoYes(Only Solaris and Linux)No
1.6.0_00YesNoYesYes

Generally, the heap dump file will be generated as java_pid3524.hprof

3. Simplest Way To Find Memory Leaks

  1. Eclipse Menu Window → Open Perspective → Memory Analyzer
  2. Eclipse Menu File → Open the Heap Dump => Select the hprof file such as java_pid3524.hprof
  3. The Overview Diagram will be displayed
  4. Click the “Leak Suspects” Report Link
  5. Click Problem Suspect 1 Details link

    You will see
Class nameShallow HeapRetained HeapPercentage
java.lang.Object2261945 @ 0×23d040409,047,792273,923,02497.00%
com.starcite.commonsearch.client.vendor.impl.VendorImpl @ 0×16b800001351360.00%

So, “java.lang.Object2261945 @ 0×23d04040” costs around 9M shallow heap (which means directly referred memory), and 273 M retained heap (which means all memory directly or un-directly referred). Now, we can know this is the root cause of memory leak.

So, what’s next? Of course, next step is trying to find which codes cause this issue?
However, it is not an easy thing. You have to use your experiences now.

Any information we can use it as start point? You can find the following information –
Accumulated Objects

Class nameShallow HeapRetained HeapPercentage
java.lang.Thread @ 0×18ff9320 http-8080-188273,945,73697.01%
java.util.ArrayList @ 0×18ff93a024273,923,04897.00%
java.lang.Object2261945 @ 0×23d040409,047,792273,923,02497.00%
com.starcite.commonsearch.client.vendor.impl.VendorImpl @ 0×16b800001351360.00%

From this view, the memory is used by java.lang.Thread @ 0×18ff9320 http-8080-1. So, it should be happened within one HTTP request.

Then, find this thread within Thread Details section. And click Thread Properties link. Please see

And now you may find some hints, such as VendorSearchMediator, SearchVendorByIDsInput etc. Based on these information, you probably find the root codes –

public SearchVendorByIDsOutput searchVendorByIDs(SearchVendorByIDsInput input) {

List
< vendor > vendors = new ArrayList </ vendor >< vendor > ();

for (;;) {
VendorImpl v
= new VendorImpl();
v.setName(
" name " );
vendors.add(v);
}
}
</ vendor >

4. How to find the memory occupied unused collections – Powerful Object Query Language 1

During the development, you may never notice that a huge number of collections which have been instantiated, but have never been used.

An empty ArrayList, created with the default capacity of 10, costs 80 bytes on a 32 bit system, and 144 bytes on a 64 bit system.

If the class MyValueStorage is commonly used in our application, and there are 500.000 instances of it in the heap, then there will be 80Mb on a 32 bit system (on 64 bit – 144MB) reserved for the specialValues and erroneousValues lists. But only about 5% from them are ever needed. Therefore, it may be a good idea to use a lazy initialization for these two fields (keep them null untill they are actually used). The cost we have to pay is several “if” statements to avoid running into NullPointerExceptions.

  1. Open Object Query Language Studio to execute statements
  2. Check the help pages for a detailed description of the OQL syntax. For the moment we need only a few concrete queries. For finding enpty and unmodified ArrayLists, HashMaps and Hashtables they look like this:
    select * from java.util.ArrayList where size=0 and modCount=0
    select * from java.util.HashMap where size=0 and modCount=0
    select * from java.util.Hashtable where count=0 and modCount=0
  3. See . Then you can get Retained Heap for each item, such as 80 bytes. And there are totally 857 entries. So, they doesn’t take too much memory.

5. How Many Memory used by VendorImpl – Powerful Object Query Language 2

  1. Open Object Query Language Studio to execute statements
  2. Run the following OQL - select * from com.starcite.commonsearch.client.vendor.impl.VendorImpl
  3. Click “show s Histogram” – see VendorImpl-Histogram.jpg. And you will find VendorImpl costs more than 260M. That’s very special.

In summary, Eclipse Memory Analyzer is a very powerful memory analyzer tool. And it can easier find potential memory leaks. And you can also find the memory used by any java object.

BTW, there are some related blogs which are very useful.
http://wiki. eclipse.org/index.php/MemoryAnalyzer - the main entry for this tool
http://kohlerm.blogspot.com/ the blog of Markus Kohler, one of the architect of Eclipse Memory Analyzer
https://www.sdn.sap.com/irj/scn/weblogs?blog=/pub/u/1203, the blog of Krum Tsvetkov

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值