December 16, 2010, 9:23 AM — VMware customers run an average of 12.5 virtual machines on each physical server, but high levels of consolidation are driven in large part by proliferation of multi-core servers, and memory limitations may be preventing further progress.
The data comes from virtualization management vendor VKernel, which analyzed 550,000 virtual machines across 2,500 deployments over a period of eight months. VKernel says the data was collected anonymously through free software tools the vendor offers to VMware customers.
The average customer in the sample has 18 physical hosts and 225 virtual machines, or 12.5 per server. Smaller customers are actually driving the ratios up, as businesses that installed VMware on fewer than 10 physical hosts are getting 20 VMs onto each server. Those with 25 to 100 hosts only deploy 11 VMs per server.
When asked why larger deployments would have fewer VMs per physical host, VKernel chief marketing officer Bryan Semple says, "Either the larger environments have an embarrassment of wealth and hence are not as efficient, or they have larger applications running on them."
Putting more than a dozen virtual machines on each box greatly changes the economics of IT, compared to the old model of one application and operating system per server.
While VMware's virtualization software makes it possible, Semple notes that the consolidation ratios also could not be achieved without advancements in multi-core technology from Intel and AMD. With the average customer using a dual-socket, quad-core machine (for a total of eight cores), customers are getting fewer than two virtual machines onto each core.
"It's not that we've gotten any better with capacity planning," Semple says of the rise in VMs per host. "It's that Intel and AMD have succeeded in getting more cores on each host." Two virtual machines per core "is not a huge amount of compression," he says. Semple predicts that over time the number of virtual machines per core will stay the same but that "more and bigger cores will be thrown at the problem."