Meu entendimento é que um dos grandes benefícios do uso de uma VM é que você pode compartilhar recursos entre as máquinas virtuais em um host. Assim, você pode ter um host com 120 CPUs e colocar 5 VMs nele com 32 CPUs cada. As CPUs extras são "compartilhadas" entre as VMs, com o host atribuindo CPUs dinamicamente com base na necessidade. O mesmo para a memória.
Também entendi que isso é um grande não-não para VMs que hospedam servidores SQL, mas meus administradores de VM discordam. Alguém tem alguma evidência ou documentação de uma maneira ou de outra?
Não sei se isso importa, mas estamos usando o VMWare.
sql-server
virtualisation
vmware
Kenneth Fisher
fonte
fonte
could
seria compartilhado. Quando eu estava fazendo a pergunta, percebi que poderia muito bem ser diferente para CPUs e memória, mas que ambas eram uma opção.Respostas:
O que você está perguntando é: "Tudo bem se nós comprometemos demais as CPUs?"
Tudo bem até você começar a enfrentar gargalos de desempenho relacionados ao consumo de CPU. A mesma resposta também é verdadeira com o comprometimento excessivo da rede - não é como se você estivesse colocando 5 placas Ethernet de 10Gb separadas no host e dedicando uma placa por VM. A virtualização tem a ver com comprometimento excessivo e na linha entre disponibilidade de recursos e requisitos de recursos.
De um modo geral, você não deseja comprometer demais a memória, pois o SQL Server usará ativamente qualquer memória que você apresentar a ele. Em vez de deixar a página das VMs no disco do host, é melhor fazer uma análise VM por VM para descobrir quais VMs poderiam viver com menos memória e depois configurá-las com menos memória para começar.
fonte
O problema que vejo ao ter alocação dinâmica de alguns recursos é que isso leva a um desempenho imprevisível. A consulta de relatório x tinha 32 CPUs disponíveis ontem e foi executada em 4 minutos, hoje possui apenas 24 e demorou consideravelmente mais. Você também pode ver a latência enquanto o convidado aguarda a disponibilidade de outros núcleos.
Jonathan Kehayias dá alguns avisos práticos sobre a inscrição excessiva de CPU e memória aqui (e, sinceramente, confio na sua experiência e conselhos mais do que um administrador típico de VM, sem ofensa a eles, mas suspeito que ele tenha uma experiência muito mais direta com a combinação):
fonte
Meu entendimento é que algum nível de comprometimento excessivo da CPU pode estar perfeitamente bom, mas isso depende totalmente dos requisitos de carga de trabalho de todos os convidados. Confira o blog de David Klee para obter muitas informações boas sobre VM. Especificamente http://www.davidklee.net/articles/sql-server-articles/cpu-overcommitment-and-its-impact-on-sql-server-performance-on-vmware/ para explicação de comprometimento excessivo da CPU e seu impacto no SQL Server.
O comprometimento excessivo da memória é outro animal inteiramente e, em geral, o host da VM não deve ser comprometido demais na memória se estiver executando servidores SQL. Mais uma vez, usarei David Klee como referência. http://www.davidklee.net/2013/11/04/lock-pages-in-memory-in-sql-server-on-vmware-why-or-why-not/ onde ele explica os efeitos da memória sobre -comprometimento.
Espero que isto ajude.
fonte