Idea #11139
Updated by Peter Amstutz almost 8 years ago
There's a discrepancy between the RAM of a VM used to choose what size node to boot for a job, and the actual amount of memory available to the job. If a job falls in the "donut hole", the job will be unable to run because the request is larger than the actual memory available, but node manager won't boot up a properly sized node because it will believe that the job is satisfied. <pre> tetron@compute3.c97qk:/usr/local/share/arvados-compute-ping-controller.d$ awk '($1 == "MemTotal:"){print ($2 / 1024)}' </proc/meminfo 3440.54 </pre> <pre> df -m /tmp | perl -e ' > my $index = index(<>, " 1M-blocks "); > substr(<>, 0, $index + 10) =~ / (\d+)$/; > print "$1\n"; > ' 51170 </pre> <pre> tetron@compute3.c97qk:/usr/local/share/arvados-compute-ping-controller.d$ sinfo -n compute3 --format "%c %m %d" CPUS MEMORY TMP_DISK 1 3440 51169 </pre> <pre> >>> szd["Standard_D1_v2"] <NodeSize: id=Standard_D1_v2, name=Standard_D1_v2, ram=3584 disk=50 bandwidth=0 price=0 driver=Azure Virtual machines ...> >>> </pre> For Standard_D1_v2 there is a ~144 MiB discrepancy between the advertised RAM size and the amount of RAM considered available by Linux. <pre> CPUS MEMORY TMP_DISK 2 6968 102344 </pre> <pre> <NodeSize: id=Standard_D2_v2, name=Standard_D2_v2, ram=7168 disk=100 bandwidth=0 price=0 driver=Azure Virtual machines ...> </pre> For Standard_D1_v2 it is 200 MiB. Based on discussion: Write a script which uses libcloud to create a VM of a given size, log in, record the value of "MemTotal" frow /proc/meminfo, and then shuts down the node. Use this information to add configuration overrides for "ram" in node manager should reduce the RAM node size for node by 5% from the "sticker value" in the ServerCalculator (jobqueue.py) configuration.