Getting JVM heap size, used memory, total memory using Java Runtime
- By Viral Patel on May 19, 2009
Reading runtime information about Java is useful sometime when your application is struggling in getting resources. System Memory is one of the main resource that an application developer has to consider while managing the application.
Hence sometimes it is beneficial to see what amount of memory is your application using and what is the free memory in system.
Java’s Runtime class provide lot of information about the resource details of Java Virtual Machine or JVM. The memory consumed by the JVM can be read by different methods in Runtime class.
Following is the small example of getting/reading JVM Heap Size, Total Memory and used memory using Java Runtime api.
/**
* Class: TestMemory
* @author: Viral Patel
* @description: Prints JVM memory utilization statistics
*/
public class TestMemory {
public static void main(String [] args) {
int mb = 1024*1024;
//Getting the runtime reference from system
Runtime runtime = Runtime.getRuntime();
System.out.println("##### Heap utilization statistics [MB] #####");
//Print used memory
System.out.println("Used Memory:"
+ (runtime.totalMemory() - runtime.freeMemory()) / mb);
//Print free memory
System.out.println("Free Memory:"
+ runtime.freeMemory() / mb);
//Print total available memory
System.out.println("Total Memory:" + runtime.totalMemory() / mb);
//Print Maximum available memory
System.out.println("Max Memory:" + runtime.maxMemory() / mb);
}
}
You may also want to print the memory utilization in Kilobytes KBs. For that just assign 1024 value to the int variable mb.
Get our Articles via Email. Enter your email address.
Thanks for this, saved me typing
Hi Viral,
I want to get JVM heap size of WebS portal server pre/post its restarts.
Is there any way I can run the above script on RHEL linu box and get it working.
Please advise.
Vishwanath
I believe you can do this with Sun/Oracle’s jmap utility
find the pid(process Id or Task Id of the JVM process/task and e.g
e.g jmap 1477
It should work try it?
Can you explain to me why the settings do not match the reported amounts?
e.g
java -Xms65m -Xmx256m TestMemory
comes out:
##### Heap utilization statistics [MB] #####
Used Memory:0
Free Memory:61
Total Memory:62
Max Memory:227
Since no memory is used shouldn’t I have 65MB yet I see only 61MB what happened to 4MB?
Also the Maximum was set to 256 and yet the max shows 227MB. What is happening here?
Overhead? From what ???
It’s just a bug, and one that won’t be resolved, as per:
http://bugs.sun.com/bugdatabase/view_bug.do?bug_id=4391499