<html><head><meta http-equiv="Content-Type" content="text/html charset=utf-8"></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;" class=""><div><blockquote type="cite" class=""><div dir="ltr" class=""><div class="gmail_extra"><div class="gmail_quote"><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div style="word-wrap:break-word" class=""><div class=""><span class=""><font color="#000000" class="">Hi Ruslan,</font><br class=""></span></div></div></blockquote></div></div></div></blockquote><div><br class=""></div><br class=""><blockquote type="cite" class=""><div dir="ltr" class=""><div class="gmail_extra"><div class="gmail_quote"><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div style="word-wrap:break-word" class=""><div class=""><span class=""><div class=""><br class=""></div></span>Ok, but I don’t believe you need a full collection to release memory back to the OS. Released memory should come from high memory regions and those regions will be empty under most circumstances after a young gen collection. A reduction of heap size should put the live data set size over the IHOP meaning you should almost immediately trigger a concurrent mark cycle.</div></div></blockquote><div class="">Hi <span style="color:rgb(34,34,34);font-family:arial,sans-serif;font-size:small;font-style:normal;font-variant-ligatures:normal;font-variant-caps:normal;font-weight:400;letter-spacing:normal;text-align:start;text-indent:0px;text-transform:none;white-space:normal;word-spacing:0px;background-color:rgb(255,255,255);text-decoration-style:initial;text-decoration-color:initial;float:none;display:inline" class="">Kirk, thank you for the additional comments. <span style="color:rgb(34,34,34);font-family:arial,sans-serif;font-size:small;font-style:normal;font-variant-ligatures:normal;font-variant-caps:normal;font-weight:400;letter-spacing:normal;text-align:start;text-indent:0px;text-transform:none;white-space:normal;word-spacing:0px;background-color:rgb(255,255,255);text-decoration-style:initial;text-decoration-color:initial;float:none;display:inline" class="">Such feedback brings us closer to a better solution. We will discuss with Rodrigo these technical points and follow-up.  </span></span></div></div></div></div></blockquote><div><br class=""></div>It appears as if the OpenJDK team is open to accepting what I’d call your less than desirable solution to this problem so I do hope that you will still explore the possibility of releasing memory after a young collection. The advantage is that this would actually offer a means to resize without a speculative call to a full collection. And, it could work on any GC cycle. Also, Gil’s and my continued conversation with Michal seem to lead me to believe that there are some unreasonable expectations w.r.t. how weak references work and how the may, or may not be cleared by the collector. It seems to me that it would benefit you to explore that gap before offering a modification of the JVM. In other words, fix the problem at the right layer and if that layer happens to be the JVM, so be it. I’m not convinced that it is in this case and I have a strong feeling that your benchmark is busted in that it’s asking the collector to do something that it shouldn’t and so tricking it to do it on a trigger isn’t really a fair measure of what is happening. That said, the OpenJDK team seems willing to accept the patch.. and quite frankly, having the JVM be able to return heap to the OS would be nice.. just not at the expense of a Full.<br class=""><blockquote type="cite" class=""><div dir="ltr" class=""><div class="gmail_extra"><div class="gmail_quote"><div class=""> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div style="word-wrap:break-word" class=""><div class=""><br class=""></div><div class="">As for the idle comment, if you’re idle why not simply shutdown JVMs in your cluster?</div></div></blockquote><div class=""><div style="color:rgb(34,34,34);font-family:arial,sans-serif;font-size:small;font-style:normal;font-variant-ligatures:normal;font-variant-caps:normal;font-weight:400;letter-spacing:normal;text-align:start;text-indent:0px;text-transform:none;white-space:normal;word-spacing:0px;background-color:rgb(255,255,255);text-decoration-style:initial;text-decoration-color:initial" class="">Possible, but doing horizontal scaling with a special logic may be overkilling for many projects. <span style="color:rgb(34,34,34);font-family:arial,sans-serif;font-size:small;font-style:normal;font-variant-ligatures:normal;font-variant-caps:normal;font-weight:400;letter-spacing:normal;text-align:start;text-indent:0px;text-transform:none;white-space:normal;word-spacing:0px;background-color:rgb(255,255,255);text-decoration-style:initial;text-decoration-color:initial;float:none;display:inline" class="">It should be tuned and maintained. <span style="color:rgb(34,34,34);font-family:arial,sans-serif;font-size:small;font-style:normal;font-variant-ligatures:normal;font-variant-caps:normal;font-weight:400;letter-spacing:normal;text-align:start;text-indent:0px;text-transform:none;white-space:normal;word-spacing:0px;background-color:rgb(255,255,255);text-decoration-style:initial;text-decoration-color:initial;float:none;display:inline" class="">It's more efforts and complexity. Java users</span> need a platform for that.</span> You can imagine how many applications are running in a single or two tomcats on the mass market. </div></div></div></div></div></blockquote><div><br class=""></div>I fear you’re correct on this point….</div><div><br class=""></div><div>Kind regards,</div><div>Kirk</div><div><br class=""></div></body></html>