Kami baru saja membeli server yang menjalankan bare metal Hyper-V 2008 R2. Server memiliki dua prosesor Intel Xeon quad-core dengan hyperthreading, jadi jika saya mengerti benar ini memberi kita 16 core. Dalam Hyper-V kami telah membuat mesin virtual yang menjalankan Windows Server 2008 R2 dengan 4 prosesor virtual. Layar pengaturan prosesor memberi tahu saya bahwa ini mewakili 25% dari total daya pemrosesan sistem. Apakah ini berarti bahwa 75% sisanya tidak dapat disadap oleh OS virtual? Kami akan menjalankan beberapa mesin virtual lainnya, tetapi yang ini untuk SQL Server dan kami ingin memberikan sebanyak mungkin tenaga kuda.
14
Jawaban:
VCPU hanya dapat dipetakan ke satu CPU fisik. Anda tidak dapat mengambil 4 CPU fisik dan membuat vCPU tunggal yang 4x lebih cepat; hanya saja bukan cara kerjanya.
Hyper-V terbatas untuk menetapkan 4 vCPUs ke VM (terakhir saya periksa). Jika Anda membutuhkan daya CPU yang signifikan, lakukan fisik, tidak ada gunanya menambahkan overhead virtualisasi ke sesuatu yang intensif dan paralel CPU di tempat pertama.
Juga, seperti yang dicatat Holocryptic, jika Anda menetapkan 4 vCPUs ke VM, VM itu tidak dapat berjalan sampai Hyper-V telah memperoleh 4 core CPU fisik untuk menjalankannya. Bergantung pada konfigurasi Anda, ini bisa menjadi batu sandungan utama (mis., Jika Anda memiliki mesin 6-inti dengan banyak VM vCPU, hanya satu yang akan berjalan pada satu waktu, dua core lainnya akan selalu berjalan pada dasarnya tidak digunakan).Menurut Jake Oshins ini tidak benar untuk versi Hyper-V. Dia menyatakan bahwa Hyper-V tidak menggunakan penjadwalan geng untuk CPU; seperti hampir semua hypervisor lainnya. Dengan demikian, jika satu inti CPU fisik tersedia, Hyper-V dapat menggunakannya untuk menjalankan VM multi-CPU. (Disebutkan juga, Hyper-V mungkin tidak menggunakan semua core fisik yang tersedia pada saat itu karena partisi NUMA)Catatan: SQL tidak harus menggunakan semua core yang bisa Anda lemparkan. Ini benar-benar tergantung pada apa yang Anda gunakan untuk dan seberapa paralel bebannya.
sumber
Ya, apa kata Chris. Jika Anda membutuhkan lebih dari 4 CPU dalam mesin virtual Hyper-V maka buatlah dua server SQL dalam virtual dan sebarkan database Anda atau lakukan fisik. Bergantung pada lisensi server SQL Anda, Anda mungkin dapat menambahkan lebih banyak server SQL dalam virtual (pada host fisik yang sama) tanpa menimbulkan biaya lisensi lebih banyak, tetapi baca kertas putih lisensi virtual SQL untuk info lebih lanjut.
Saya juga setuju bahwa jika Anda memiliki SQL kehabisan daya CPU dengan 4 CPU virtual maka Anda punya beberapa pemanfaatan aplikasi serius atau perintah SQL ditulis dengan buruk.
sumber
Tentang 4 batas inti CPU:
Di bagian file konfigurasi VM:
[prosesor] [tipe hitung = ”integer”] 16 [/ hitung]
Sekarang Anda memiliki 16 core CPU.
UPDATE: Tampaknya tangkapan layar diperlukan
sumber
ikuti panduan ini
http://surminski.eu/2012/04/17/hyper-v-how-to-add-more-than-4-cores-to-a-virtual-machine/
Anda dapat menemukan file konfigurasi vm xml di bawah direktori "Mesin Virtual" dari direktori VHD VM, file konfigurasi akan diberi nama di bawah id VM. Tautan di bawah ini adalah referensi.
referensi: file konfigurasi VM xml
pastikan Anda mengedit file konfigurasi VM xml dengan notepad / notepad ++ dibuka di bawah hak administrator
sumber