Can’t admit VM: Memory admission check failed

On a system with a lower amount of RAM you may find that ESXi allocates too much to run the vmkernel and system services not leaving sufficient memory for running VMs. In the below example, the host has 3 GB of memory. ESXi is showing about 2600 MB available for virtual machines. But an important number for virtual machines is the memory capacity shown on the Resource Allocation in the 2nd image below.

This shows that my VMs have a total capacity of just over 1400 MB for VM memory overhead. A chart of memory overhead per vCPU / VM memory is shown below. VM memory overhead includes space for the VM frame buffer and virtualization data structures like shadow page tables. Once my running VMs have exhausted the 1400 MB of total capacity, I will not be able to start additional VMs even though ESXi may have plenty of free memory.

Virtual Machine Memory Overhead*

Memory(MB)1VCPU2VCPUs3VCPUs4VCPUs5VCPUs6VCPUs7VCPUs8VCPUs
256113.17159.43200.53241.62293.15334.27375.38416.5
512116.68164.96206.07247.17302.75343.88385.02426.15
1024123.73176.05217.18258.3322363.17404.34445.52
2048137.81198.2239.37280.53360.46401.7442.94484.18
4096165.98242.51283.75324.99437.37478.75520.14561.52
8192222.3331.12372.52413.91591.2632.86674.53716.19
16384334.96508.34550.05591.76900.44942.98985.521028.07
32768560.27863.41906.06948.711515.751559.421603.091646.76
655361011.211572.291616.191660.092746.382792.32838.222884.14
1310721912.482990.053036.463082.885220.245273.185326.115379.05
2621443714.995830.65884.535938.4610142.8310204.7910266.7410328.69

Let’s say I have a 1 vCPU VM with 2 GB of memory. ESXi will need a memory overhead of about 137 MB to start the VM. But if I give it 1400 MB memory reservation, then ESXi will need an available capacity of about 1537 MB to start the VM. In my case, the VM won’t be able to start and will display the error: Can’t admit VM: Memory admission check failed. I would need to have an available capacity of more that 1537 MB to start the VM.

So if your host is experiencing this issue, but the summary page for the host is showing that you have available memory you can tweak the memory reservations for system processes to increase the size of Memory: Total Capacity. Note that this is not a supported procedure and underallocating system resources can have a negative performance impact. Select the Configuration tab and then System Resource Allocation.

Click on the Advanced link in the top right hand corner of the window to show advanced configuration options. In the below image I have selected vmvisor object and am dropping the reservation from 768 MB to 256 MB. After a few minutes the 512 MB of memory freed up from the reservation will be available on the Resource Allocation page. There are other objects which could be modified, but a change to the vmvisor reservation can quickly yield 512 MB of free memory. If an object does not let you reduce the reservation, you may get an error or the number will remain unchanged after you click OK.

Leave a Comment

Your email address will not be published. Required fields are marked *