Why am I able to set -Xmx to a value greater than physical and virtual memory on the machine on both Windows and Solaris?

前端 未结 3 365
青春惊慌失措
青春惊慌失措 2020-12-09 20:22

On a 64-bit Windows machine with 12GB of RAM and 33GB of Virtual Memory (per Task Manager), I\'m able to run Java (1.6.0_03-b05) with an impossible -Xmx setting of 3.5TB but

相关标签:
3条回答
  • 2020-12-09 20:27

    At least with the Sun 64-bit VM 1.6.0_17 for Windows, ObjectStartArray::initialize will allocate 1 byte for each 512 bytes of heap on VM startup. Starting the VM with 35TB heap will cause the VM to allocate 70GB immediately and hence fail on your system.

    The 32-bit VM (and so I suppose the 64-bit VM) from Sun does not take account for available physical memory when calculating the maximum heap, but is only limited by the 2GB addressable memory on Windows and Linux or 4GB on Solaris or possibly failing to allocate enough memory at startup for the management area.

    If you think about it, checking the sanity of the max heap value against available physical memory does not make much sense. X GB of physical memory does not mean that X GB is available to the VM when required, it can just as well have been used by other processes, so the VM needs a way to cope with the situation that more heap is required than available from the OS anyway. If the VM is not broken, OutOfMemoryErrors are thrown if memory cannot be allocated from the OS, just as if the max heap size has been reached.

    0 讨论(0)
  • 2020-12-09 20:37

    According to this thread on Sun's java forums (the OP has 16GB of physical memory):

    You could specify -Xmx20g, but if the total of the memory needed by all the processes on your machine ever exceeds the physical memory on your machine, you are likely to end up paging. Some applications can survive running in paged memory, but the JVM isn't one of them. Your code might run okay, but, for example, garbage collections will be abysmally slow.

    UPDATE: I googled a bit further and, according to the Frequently Asked Questions About the Java HotSpot VM and more precisely How large a heap can I create using a 64-bit VM?

    How large a heap can I create using a 64-bit VM?

    On 64-bit VMs, you have 64 bits of addressability to work with resulting in a maximum Java heap size limited only by the amount of physical memory and swap space your system provides.
    See also Why can't I get a larger heap with the 32-bit JVM?

    I don't know why you are able to start a JVM with a heap >45GB. This is a bit confusing...

    0 讨论(0)
  • 2020-12-09 20:45

    Just to re-enforce Pascal's answer--Be very careful in windows when specifying a high max memory size. I was working on a server project that required as much physical memory as possible, but once you are over physical ram, abysmal performance is not a good description of what happens--Hung machine might be better.

    What happens (at least this is my evaluation of it after days of examining logs and re-running tests) is, Windows runs out of ram and asks all apps to free up what they can. When it asks Java, Java kicks off a GC. The GC touches all of memory (causing anything that has been swapped out to be swapped in). This in turn causes windows to run out of memory. Windows then sends a message to all apps asking them to free up what they can.... (recurse indefinitely)

    This may not ACTUALLY be what is going on, but the fact that Java GC touches Very Old Memory at times makes it incompatible with paging.

    0 讨论(0)
提交回复
热议问题