JEP 132: More-prompt finalization

Tony Printezis tony.printezis at oracle.com
Fri Jan 6 08:37:14 PST 2012


Does AddMemoryPressure() take any parameters? Creating a new socket (out 
of a max of say 1,000,000) should have different weight to, say, 
creating a new file (out of a of say 50).

Tony

On 01/06/2012 11:32 AM, Vitaly Davidovich wrote:
>
> Tony,
>
> Interestingly the .NET CLR has an API  to allow apps to tell the 
> runtime(gc specifically) to be more aggressive - 
> System.GC.AddMemoryPressure/RemoveMemoryPressure.  The idea being that 
> you'd call this when a managed object allocates native memory and thus 
> adds overall pressure.  This hint is then used by the gc.  What are 
> your thoughts on that? Granted this is more amenable for mem 
> management and not other scarce resources.
>
> On Jan 6, 2012 11:17 AM, "Tony Printezis" <tony.printezis at oracle.com 
> <mailto:tony.printezis at oracle.com>> wrote:
>
>     Kirk,
>
>     Inline.
>
>     On 01/06/2012 08:57 AM, Kirk Pepperdine wrote:
>
>         Tony, David,
>
>         I really feel that this problem is being solved at the wrong
>         level. The JVM lacks application semantics to know when to do
>         the "right" thing.
>
>
>     I absolutely agree.
>
>         So, IMHO,  this should be managed by the application.
>
>
>     I absolutely disagree. :-)
>
>     First, let's define some terminology to make sure we're all on the
>     same page:
>
>     JVM : HotSpot
>     library : the Java code that manages certain native resource
>     (e.g., classes in the java.io <http://java.io> package) - I do not
>     consider this part of the JVM
>     application : what the user writes which runs on top of HotSpot
>     and uses java.io.File's.
>
>         For the same reason, there are other things that the
>         application shouldn't touch like telling the JVM it's time to
>         run a collection.
>
>
>     Amen to that. :-)
>
>         That said, one thing the JVM might know about is how many file
>         descriptors it's allowed and it could trigger an attempt to
>         recover them (i.e. run finalization) once they start running low..
>
>
>     Indeed. But the JVM (as defined above) does not know anything
>     about file descriptors. It's the library, in this case classes in
>     java.io <http://java.io>, that does. However, I don't think said
>     library should also be calling System.gc() either. It should be
>     providing information to the GC, via the API I have been
>     suggesting, on how much of a certain resource we have and the GC
>     should be making informed decisions on whether it when it should
>     trigger a cycle.
>
>     Tony
>
>          just as the JVM manages memory by recovering it when it runs
>         low. That said, I did run a bench where we opened
>         1,000,000,000 sockets on a single VM. That is just about as
>         many sockets as can be opened on a machine without recompiling
>         the kernel to configure a bigger file descriptor bitmap. I'm
>         quite happy that the JVM wasn't fighting me as I was trying to
>         open all these sockets. While this bench was a bit extreme,
>         it's clear that WebSocket gateways *will* stress file descriptor.
>
>         Not sure about direct buffers though I do feel they should
>         implement finalization as a fallback position.
>
>         Cheers,
>         Kirk
>
>         On 2012-01-06, at 12:14 PM, David Holmes wrote:
>
>             Hi Tony,
>
>             On 6/01/2012 8:34 PM, Tony Printezis wrote:
>
>                 If each library could indicate to the GC whether the
>                 resource it manages
>                 is running low or not, using the API I mentioned, the
>                 GC could do the
>                 above automatically, behind the scenes, without the
>                 user having to do
>                 anything else.
>
>             I'm not sure a library writer has the necessary
>             information to do this. Seems to me that how an
>             application uses a particular type determines the scarcity
>             of the resource. I can imagine something like:
>
>             void setFinalizationLimit(Class<?>  cls, int limit)
>
>             so that GC runs finalization once a "reference count"
>             reaches "limit". That limits the frequency of
>             finalization, but the actual finalization cost may still
>             be unacceptably high.
>
>             Cheers,
>             David
>
>                 Tony
>
>                     Afterall the key thing about GC is it relieves the
>                     programmer from
>                     having to manage object lifetimes, so if you don't
>                     know when the
>                     object is no longer used you don't know when to
>                     call close.
>
>                     David
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: http://mail.openjdk.java.net/pipermail/hotspot-dev/attachments/20120106/5111f34c/attachment-0001.html 


More information about the hotspot-dev mailing list