/**
* 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);
}
}
Code language: Java (java)
You may also want to print the memory utilization in Kilobytes KBs. For that just assign 1024 value to the int variable mb. Java URL Encoder/Decoder Example - In this tutorial we will see how to URL encode/decode…
Show Multiple Examples in OpenAPI - OpenAPI (aka Swagger) Specifications has become a defecto standard…
Local WordPress using Docker - Running a local WordPress development environment is crucial for testing…
1. JWT Token Overview JSON Web Token (JWT) is an open standard defines a compact…
GraphQL Subscription provides a great way of building real-time API. In this tutorial we will…
1. Overview Spring Boot Webflux DynamoDB Integration tests - In this tutorial we will see…
View Comments
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
Hi,
in jvm initially i calculated the free memory.. then i created many variables and used it.. after garbage collection.. i again calculated free memory.. it is not equal to the initial free memory.. why this mismatch???????? plz ans me...
public class Add extends java.lang.object{
public Add();
code:
0: aload-0
1: invoke special #1;//Method java/lang/object.””()u
4: return
public static void main(java.lang.String[]);
code:
0: bipush 10
2: istore-1
3: bipush 20
5: istore-2
6: iload-1
7: iload-2
8: iadd
9: istore-1
10: return
}
i want to run command to see the jvm flags pls help me out
its very useful information to get the memory information by using application.
Thank you - used this for debugging today. Very helpful.
Used Memory is always less than the values shows up on Linux top command. Why is this difference?
top command values are not even close to TotalMemory when we give the spike. How do I get the top command values through JAVA program.
Very helpful -- thank you for posting.