Get started with java JVM memory (heap, stack, -xss -xms -xmx -xmn...)
Par Quentin Ambard le lundi, mai 3 2010, 20:23 - Lien permanent
JVM maximum size (32bit/64bit)
First of all, let's have a global look about JVM Memory.If we are using a 32bit OS, then the jvm can't have more than 4GB of RAM
Over this 4Gig, Os have their own needs. For exemple Windows needs 2GB for its kernel usage. So it left 2GB for our JVM.
But JVM implementation needs to have a continous memory region for the heap.
Here is the explanation :
The reason we need a contiguous memory region for the heap is that we have a bunch of side data structures that are indexed by (scaled) offsets from the start of the heap. For example, we track object reference updates with a "card mark array" that has one byte for each 512 bytes of heap. When we store a reference in the heap we have to mark the corresponding byte in the card mark array. We right shift the destination address of the store and use that to index the card mark array. Fun addressing arithmetic games you can't do in Java that you get to (have to :-) play in C++.
Usually we don't have trouble getting modest contiguous regions (up to about 1.5GB on Windohs, up to about 3.8GB on Solaris. YMMV.). On Windohs, the problem is mostly that there are some libraries that get loaded before the JVM starts up that break up the address space. Using the /3GB switch won't rebase those libraries, so they are still a problem for us.
We know how to make chunked heaps, but there would be some overhead to using them. We have more requests for faster storage management than we do for larger heaps in the 32-bit JVM. If you really want large heaps, switch to the 64-bit JVM. We still need contiguous memory, but it's much easier to get in a 64-bit address space.
So usually, JVM heap cannot be bigger than 1.2-1.6BG.
JVM memory overview
We could resume Java process heap with the following schema :
Java Heap & GC tuning
Java "Heap" is a continous memory region where all Objects data will be stored (by data, we mean instance of class, primitive and references). It's a big part of the process heap.It can be configured using the following parameters :
- -Xmx : max heap size (ex: -Xmx1024)
- -Xms : min heap size. Having -Xms = 1.8GB (32bit) can be bad, because you don't let memory for anything else.
- -Xmn : the size of the heap for the young generation
Young generation represents all the objects which have a short life of time. Young generation objects are in a specific location into the heap, where the garbage collector will pass often. All new objects are created into the young generation region (called "eden"). When an object survive is still "alive" after more than 2-3 gc cleaning, then it will be swap has an "old generation" : they are "survivor" .
Good size is 33% - -XX:NewRatio : the same as Wmn, but using a % (dynamic fs static -Xmn option). -XX:NewRatio=3 means that the ratio between the old and young generation is 1:3
- -XX:NewSize - Size of the young generation at JVM init. Calculated automatically if you specify -XX:NewRatio
- -XX:MaxNewSize - The largest size the young generation can grow to (unlimited if this value is not specified at command line)
- -XX:SurvivorRatio : "old generation" called tenured generation, ratio, in %. For example, -XX:SurvivorRatio=6 sets the ratio between each survivor space and eden to be 1:6 (eden is where new objects are created)
- -XX:MinHeapFreeRatio: default is 40%. JVM will allocate memory to always have as minimum 40% of free memory. When -Xmx = -Xms, it's useless.
- -XX:MaxHeapFreeRatio: default is 70%. The same as Min, to avoid unecessary memory allocation.
More informationabout Sun HotSpot GC tuning here and general gc tuning here
At this point, we get a problem. In a multithread application, object can be created at the same time. Thread could try to write data into the same heap location at the same time.
To avoid this problem, we allow each thread to have a private piece into the eden space.
jdk 1.5> uses dynamic sizing algorithm, specific for each thread. (otherwise, parameter such as -XX:UseTLAB or -XX:TLABSize can be used to tune this parameter)
And EveryThing Else...
Every thing else is...- Permanent Space : It's the third part of the memory. Here are stored classes, methods etc.
- -XX:PermSize: initial value
- -XX:MaxPermSize: max value
- Code generation : Converted byte code into native code. Shouldn't cause troubles.
- Socket Buffer (contains the 2 buffers for each sockets: receive/send)
- Thread Stacks: Each thread has its own stack. It makes possible to get your methods thread-safe.
- -Xss: change the space of a thread stack. 2048 could be a write value. It can cause a java.lang.stackOverFlow Error
- If you get a "java.lang.OutOfMemoryError : unable to create new native Thread, you can decrease -Xss or decrease the java heap using -Xmx/-Xms (to increase the thread stack space)
- Direct memory space (ability to let Java developers map memory outside the Java Object Heap. Can be adjusted using -XX:MaxDirectMemory=
- JNI Code, if you use it
- Garbage Collection (the GC has its own thread/informations)
A nice gotcha...
Major collection don't run until tenured is full.This mean that using -Xmx1024, current heap could be 750MB with 500MB of "dead" object. If the JVM is idle, it could stay like that during a very long time => wasting 500MB or RAM for an idle JVM !
More informations about GC memory & monitoring here
You should also read this awesome slideshare from Filip Hanik, Covalent (gotcha, etc... most of this informations come from this slides)
Commentaires
Thanks, you is the man...
Thanks a lot, was a real help with my app.
I savor, result in I found just what I used to be having a look for. You have ended my four day lengthy hunt! God Bless you man. Have a great day. Bye
I simply could not leave your site before suggesting that I really loved the standard info a person provide in your guests? Is going to be back frequently in order to check out new posts
Good Job. Thank you for posting that. I will come back to read more and tell my coworkers about your writing.
It is in reality a great and helpful piece of information. I'm satisfied that you simply shared this helpful information with us. Please keep us up to date like this. Thanks for sharing.
Good website. Thanks for taking the time. I will check to this site to find out more and inform my neighbors about this.
Hello there, i feel that we discovered people stopped at my web site as a result i obtained listed here to come back a pick? . I'm hunting for items to greatly enhance my site! I reckon that the enough to utilize most of your thinking!
Awesome. Thank a lot for posting this. I will definitely check here to find out more and recommend my friends about this site.
Great publish, very informative. I wonder why the opposite experts of this sector do not understand this. You should proceed your writing. I am sure, you have a great readers' base already!|What's Going down i am new to this, I stumbled upon this I have found It positively useful and it has helped me out loads. I hope to contribute & assist other users like its helped me. Good job.
I can't know generate income ended up right here, however I considered the following placed was very good. Right after exactly who you will be nonetheless undoubtedly you'll any popular tumblr so that you know already. Regards!
Valuable information. Fortunate me I discovered your site by accident, and I'm stunned why this coincidence did not happened in advance! I bookmarked it.
Hello there, I found your blog by means of Google at the same time as looking for a related matter, your web site came up, it seems to be great. I have added to favourites|added to bookmarks.
thanks, it is realy useful
Nice. Thank a lot for taking the time. I will come to this site to read more and recommend my people about you.
Well written. Thanks for posting this. I'll check again to see what's new and tell my friends about your website.
Great beat ! I wish to apprentice while you amend your web site, how could i subscribe for a weblog site? The account helped me a applicable deal. I were tiny bit familiar of this your broadcast offered vibrant transparent idea
I enjoy your site. Thank a lot for doing such a good job. I'll come back to read more and tell my coworkers about you.
Like it. Thank you for doing such a good job. I'll return again to find out more and inform my acquaintenances about this.
Wonderful items from you, man. I have understand your stuff prior to and you are simply extremely wonderful. I actually like what you've bought here, certainly like what you are saying and the way during which you are saying it. You make it enjoyable and you still take care of to keep it wise. I cant wait to learn much more from you. This is actually a wonderful site.
Loved it. Thanks for taking the time. I'll check back to see what's new and tell my acquaintenances about this.
Creative. Thank you for doing such a good job. I'll come to your site to read more and inform my friends about your posting.
Attractive part of content. I just stumbled upon your site and in accession capital to say that I get in fact enjoyed account your blog posts. Anyway I will be subscribing to your augment or even I achievement you get admission to consistently quickly.
Love it. Thank you for writing that. I'll definitely come to this site to read more and inform my friends about this website.
Wonderful site. Plenty of helpful information here. I'm sending it to some pals ans additionally sharing in delicious. And obviously, thank you on your effort!
Fabulous effectiveness on this unique world wide web site. My spouse enjoyed viewing it all, and as a consequence may well revisit many times, seeking for anything most recent.
The Akashic Records is a REAL place also known as "God's Mind" or "Universal Library". . It consists of information of every action, thought, choice that every being has made, and perhaps will make, depending on that point in time. It is said famous psychics like Edgar Cayce and Nostradamus had access to these records. . . People have reported seeing the Akashic Records differently. Some see it as a giant book, some see it as a movie. To some it looks like a giant library that holds the information of everything. You have your own book, and to my knowledge, you can access yours by telling your birth name, date, and location where you were born.. There will be consequences to those who use the Akashic Records for selfish purposes like finding out the lucky numbers of the lottery. It is also suggested that you look at only friend and family members' records if you wish to look at someone elses.. . You can access the Akashic Records by Astral Travel, Meditation, or (remote viewing?) . . Much of the time, quite honestly people can't remember vividly their astral experiences because (much like when dreaming) your consciousness is split, and your physical mind does not recognize that memory.. . The Akashic Records is a sacred place, and should not be taken lightly. Although enjoy looking at your book and maybe learn something about yourself you never knew. :)
Any OG Jordan that comes with the box, original laces, box, etc. and also if they are DS or VNDS
Super venture via this excellent ınternet site. My spouse really enjoyed reviewing it all, and as a consequence am going to keep returning repeatedly, looking for everything creative.
Fine job across this web page. I've loved searching it, and as a consequence may well revisit continually, looking to find something very new.
Excellent overall performance located on this excellent web site. My husband and i treasured examining it all, and therefore will most certainly revisit constantly, looking out for something fresh, new.
Quality performance concerning this unique website page. We loved checking it all, and thus definitely will come back many times, hunting for something creative.
Nice results with regards to this business site. Now i loved reviewing it all, and so will, no doubt revisit constantly, in search of nearly anything innovative.
Extraordinary results across this web site. My husband and i had a great time checking out it, and furthermore may very well revisit time and again, attempting to find nearly anything creative.
Fantastic work attached to this valuable world wide web site. I relished browsing on it again, and as a consequence definitely will return very often, wanting to find nearly anything innovative.
Fine results on this amazing site. I've treasured looking at it all, and furthermore will definitely return very often, on the search for anything very new.
Impressive venture on this excellent website page. My husband and i appreciated browsing the idea, and as a consequence will reappear constantly, in search of everything new.
Marvelous endeavor directly on this unique website online. Naturally i loved looking through it again, and therefore will most certainly reappear very often, seeking for nearly anything interesting.
Good venture with regards to this excellent online site. My hubby and i took pleasure surfing around the idea, and thus may revisit quite often, looking out for something brand new.
Really good presentation across this unique website online. I've appreciated browsing on it, and will keep coming back often, hunting for anything new.
Exceptional results via this unique website page. I actually liked browsing it, and so will definitely reappear constantly, on the search for just about anything creative.
Extraordinary performance located on this amazing internet page. Anyway i took pleasure in checking this, and in addition may possibly keep returning quite often, hunting for everything unique.
Magnificent entire performance located on this excellent website. My spouse took pleasure examining it again, and in addition may come back very often, looking out for just about anything completely new.
You're actually a excellent webmaster. The website loading speed is amazing. It sort of feels that you are doing any unique trick. Also, The contents are masterwork. you have performed a fantastic task on this subject!
Incredibly good functionality available on this amazing internet page. I actually treasured checking the idea, and furthermore will probably keep coming back oftentimes, browsing for anything different.
I have been previously searching on-line greater than about three a long time currently, nevertheless Irrrve never discovered almost any fascinating post similar to the one you have. It is pretty importance enough for me. I think, in the event almost all online marketers plus web owners designed beneficial articles when you most likely have, online generally is a many more valuable than ever.
Excellent goods from you, man. I have remember your stuff prior to and you are simply too excellent. I really like what you have obtained here, really like what you are stating and the way in which wherein you say it. You're making it enjoyable and you still take care of to keep it sensible. I cant wait to learn far more from you. This is really a great web site.
Remarkable issues here. I am very happy to see your post. Thanks a lot and I'm having a look forward to touch you. Will you kindly drop me a e-mail?
You really make it appear so easy with your presentation but I in finding this matter to be really one thing which I believe I'd never understand. It kind of feels too complex and extremely wide for me. I am having a look forward in your subsequent put up, I'll attempt to get the cling of it!
Great performance on this website. I enjoyed browsing it, and will come back often, looking for anything new.
Pretty element of content. I just stumbled upon your site and in accession capital to assert that I get actually loved account your blog posts. Anyway I will be subscribing for your augment and even I fulfillment you get right of entry to consistently rapidly.
Great weblog right here! Additionally your website a lot up very fast! What host are you the usage of? Can I get your affiliate hyperlink for your host? I wish my site loaded up as fast as yours lol
I've been exploring for a little for any high-quality articles or blog posts in this kind of house . Exploring in Yahoo I finally stumbled upon this web site. Reading this information So i'm satisfied to convey that I've a very just right uncanny feeling I came upon exactly what I needed. I most no doubt will make certain to do not put out of your mind this web site and give it a glance on a relentless basis.
I simply could not leave your site before suggesting that I extremely enjoyed the standard information a person provide on your visitors? Is going to be again ceaselessly to check out new posts
Thanks , I've just been looking for info approximately this topic for a while and yours is the greatest I've came upon so far. But, what about the bottom line? Are you sure concerning the source?|What i do not understood is actually how you're no longer actually a lot more well-liked than you may be now. You're very intelligent.
It is appropriate time to make a few plans for the long run and it is time to be happy. I've read this put up and if I could I desire to counsel you few attention-grabbing issues or suggestions. Maybe you can write subsequent articles referring to this article. I desire to read even more things about it!
Hiya very cool site!! Guy .. Excellent .. Superb .. I will bookmark your site and take the feeds also?I'm glad to search out a lot of helpful information right here in the post, we want develop more techniques on this regard, thanks for sharing. . . . . .
You are in point of fact a excellent webmaster. The web site loading speed is amazing. It seems that you're doing any distinctive trick. In addition, The contents are masterpiece. you've performed a excellent job on this subject!
Excellent overcom! I wish to newbie even though you amend your site, how could possibly my partner and i register for a web log? The actual bank account helped me a useful deal. My partner and i have been a little bit comfortable on this a person's transmit supplied glistening obvious thought
I just couldn't depart your web site before suggesting that I actually enjoyed the standard info an individual supply for your guests? Is going to be again regularly in order to check out new posts
Heya i'm for the first time here. I found this board and I find It truly helpful & it helped me out much. I am hoping to provide one thing back and aid others like you aided me.
I have been surfing online greater than three hours these days, yet I by no means discovered any attention-grabbing article like yours. It is lovely worth sufficient for me. In my view, if all website owners and bloggers made good content material as you probably did, the net will likely be a lot more useful than ever before.
We do take into account the many suggestions you've got presented for your post. They're just begging and can certainly do the job. Still, the blogposts are way too shorter for freshies. May possibly you desire expand these people somewhat coming from pursuing time frame? Thank you for the particular publish.
Amazing, wonderful weblog structure! The span of time have you been writing a blog with regard to? you are making writing a blog peek straightforward. The entire appear of your respective web site is superb, aside from the material!
It's appropriate time to make a few plans for the longer term and it is time to be happy. I've read this submit and if I could I desire to suggest you some fascinating issues or tips. Maybe you could write subsequent articles relating to this article. I want to learn even more issues approximately it!
You could definitely see your expertise in the work you write. The world hopes for even more passionate writers like you who are not afraid to say how they believe. All the time follow your heart.
Hey very cool site!! Guy .. Excellent .. Amazing .. I will bookmark your blog and take the feeds additionally?I am glad to seek out numerous useful info here within the post, we want work out extra techniques on this regard, thank you for sharing. . . . . .
We're a variety of volunteers and also opening up a whole new structure in the local community. Your site made available you along with helpful information for you to work with. You've done a notable method plus each of our total community are going to be glad back.
Heya i am for the primary time here. I found this board and I find It really useful & it helped me out much. I am hoping to provide one thing again and aid others like you aided me.
Thanks a lot regarding spreading the following wonderful men and women you actually determine what you will be discussing somewhere around! Added. Kindly moreover check with my website Means). We will have got a exchanging links commitment concerning united states