This guide will walk you through setting up a cluster in Hyper-V with Failover Cluster Manager and System Centre Virtual Machine Manager

You’ll ideally want 2+ nodes for this
This guide will also run you through using on board local storage, EG Dell BOSS, for boot, and then iSCSI from a SAN for everything else

This has also been tested as part of a live deployment using real world hardware, but this guide will focus on specs for a virtual environment, networking though is the same

Virtual Host Specs – Minimum
4 vCPU
30GB RAM – This gives us enough to run some VMs and test
~80GB Drive for Windows, direct attached
10GB iSCSI drive for Quorum
A drive for VM data, Eg 500GB, iSCSI
10 NICs with a total of 5 networks, these should be redundancy networks, in my lab deployment iSCSI is Teamed, you may also wish to have 2 separate NICs for two fault domains for iSCSI, but the rest should be teamed NICs

  • Management
  • iSCSI
  • Live Migration
  • Cluster
  • VM Traffic

Here is an example host from my deployment, this has slightly beefier specs, here management and VM run of the same /24 network for the Hyper-V Lab, is production the VM traffic may be the same network but is also likely trunked at the switch level for VM VLAN tagging
But generally your Hyper-V host should really look like a switch for the networking

Stage 1 – Preparation
1.1 – Hyper-V Installation

First you’ll need a standard install of Windows server

To install Hyper-V you need to add the role to your server, open Server manager and on the top right click Add Roles Or Features

Click next here

Keep the default role or feature based installation

Select a server from the pool, if you have a pool, if not like I do, your server will already be selected

Check Hyper-V here

And then add the features

Click next here, we dont need any features

Click next again

I am skipping over the networking, as I will be setting that up later, so just click next here

Leave this blank, even if you are clustering Hyper-V you want to set this up later

You can specify the default storage location here, I will be using an iSCSI disk from a SAN, so I am leaving tis blank as that disk isnt mapped yet

Then hit install

Then reboot your host and Hyper-V will be installed

1.2 – Enabling MPIO

For a Windows server to be able to map an iSCSI disk it needs to have the role for Multipath IO added from server manager

Open server manager and add a role or feature

From there click next till you get to the features, add Multipath IO

Then next, next again and install

1.3 – Mapping Disks

Now that iSCSI has been added we need to map the disks to the server, open MPIO

Add support for iSCSI devices and click ok

Then open the iSCSI initiator settings

If the iSCSI service isnt running, enable it

From here we can use dynamic discovery by adding the IP of our target, and using Quick Connect

Once you click Quick Connect, we can add the targets, I am mapping the Hyper-V target

Now it will show as connected

Then from PowerShell, claim the disks for MPIO to fully use with
mpclaim -r -i -a “”

From disk manager you can then bring the disk online

Initialise the disk

Setup a GPT partition

And create a new volume

You’ll need to create a new NTFS or ReFS partition to be able to use the disk in CVS later on

1.4 – Enabling Jumbo Frames

To do this edit this interface from the network and sharing centre, I will be editing my iSCSI NICs, before creating the team, this is Ethernet4/5

Then properties

Click configure

Then under advanced you can enable jumbo frames

Then create your team, as this inherits the MTU of the adapters

To test this, ping the iSCSI IP with a high MTU with this command
ping <iSCSI-IP> -f -l <MTu>
A good value for an iSCSI network, which should have an MTU of 9000, is an MTU of 8800

1.5 – Failover Clustering Installation

To install Fail Over Cluster Manager you need to add the Feature to your server

Open server manager and add a role or feature in the top right

Click next

Next again, making sure your server is selected

Next over the roles

Check failover clustering

Click add features

Then install

1.6 – Setting Up NIC Teaming

For redundancy you will want to configure NIC teaming to use 2 physical ports for one connection

I am going to setup NIC teaming for my Windows Server management
From the local server in Server manager, enable NIC teaming

Ensure your server is selected at the top

Then lets create a new task to add a teaming for management and select our NICs

Lets name the Team, ensure the right NICs are being used, I want active passive, so Ethernet1 is setup as standby, and I am leaving the VLAN as the default, as the switch these hosts connect to has the VLAN sorted

Once its done it should look like this

If you had management configured on Ethernet0, like I do, this will wipe it and you need to configure the networking for the Team, Management, via control panel

1.7 – Setting Up A Teamed vSwitch

You’ll need two adapters for this, not in any Team, as Hyper-V has deprecated LBFO, this needs to be done via PowerShell and will setup an active passive setup with both NICs able to do traffic with the throughput of 1 NIC

To see your NICs with their names for the command to create a vSwitch use
Get-NetAdapter

First, disable VM queues on the NICs you want to use on the Team with
Disable-NetAdapterVmq -Name “NICx”
Disable-NetAdapterVmq -Name “NICy”

For me, I am ising Ethernet2 and Ethernet3 so my command is
Disable-NetAdapterVmq -Name “Ethernet2”
Disable-NetAdapterVmq -Name “Ethernet3”

To create a new vSwitch use the following substituting NICx and NICy for the NICs you want to use, you can add NICz for example if you want more
New-VMSwitch -Name “<vSwitch Name>” -NetAdapterName “NICx”,”” -EnableEmbeddedTeaming $true -AllowManagementOS $false

I am using Ethernet2 and  so my command is
New-VMSwitch -Name “VM Data” -NetAdapterName “Ethernet2″,”Ethernet3” -EnableEmbeddedTeaming $true -AllowManagementOS $false

If you check the adapters now, you will see the new adapter

You can see the vSwitch in Hyper-V switch manager, but you cant manage it, it is also using both NICs despite not showing it

If you use ipconfig to view the DHCP IP assigned to that new adapter, the pings work with no drops if you disable the 2 adapters one at a time, this works only if you have -AllowManagementOS $true, which I used for testing the redundancy out, if management allowed is false, it wont have an IP

You can also view the switch with
Get-VMSwitch

1.8 – Setup WAC (Optional)

Firstly, download the latest Windows Admin Centre From here
And join your WAC server to the domain

Run the executable, and select the diagnostic data

Enable Microsoft updates

Click next here

Leave the defaults here, and click next

Leave the default port as 443 and generate a self signed certificate unless you want a specific certificate

When you log in, it will update all extensions for you

You will also want to add Teams for configure the IPs for iSCSI, Live Migration and Cluster networks like management, Live Migration/Cluster should be separate non routable networks, for Live migration I would recommend using Active/Standby

Stage 2 – Failover Cluster Manager
2.1 – Creating The Cluster

Open the failover cluster manager app

Click create cluster on the right

Add the servers you want to use to a cluster

Keep it on yes to validate the cluster, this will tell you if there are any glaring issues

Click next

Next again to run all tests

And next one last time to start it

Double check any issues it might have, and if they likely wont impact the cluster, name your cluster

I want to configure the storage manually later, so I have unchecked the box, once you are happy click next

Once its done it will give you an overview

2.2 – Deploying The CSV

Once you have nodes added to failover cluster manager and a cluster setup, you can deploy CSV volumes from iSCSI storage

And add a disk on the right

I have 1 500GB drive I plan to use for VMs
What you’ll notice is that only those one disk shows, despite being shared via iSCSI to all 3 nodes, and 1 node controls the disk, so the 500GB drive only appears once

If you were to open disk manager, you’ll notice disk 1 is offline and is reserved and offline and cannot be brought online, this is normal

Now the cluster disk is available with HyperV3 as the owner node

If we right click it, we can add it to a Cluster Shared Volume

Now you can see its assigned to the Cluster Shared Volume, and the owner node has changed, this will happen from time to time

The disk registered in disk manager as a CSVFS disk now, rather than something more traditional like NTFS, this is because a different file system that is shared volume aware is needed, like VMware’s VMFS

The disks dont get mounted onto This PC like normal drives, they are locked under C:\ClusterStorage

If we right click the volume and go to properties we can rename the volume to what ever you want
This is off my TrueNas server on a pool called Luna, so I have named it accordingly, this can be whatever you want though

2.3 – Cluster Networking

Under networks in Failover Cluster Manager you’ll see any networks with IP addresses the cluster can use
Its worth noting the SET Team vSwitch we created earlier will NOT show up here as it doesnt have an IP and is for clients only, so thats normal

Cluster networks will often be for you iSCSI, Management, Cluster Heartbeat and Live Migration Networks, I have renamed a couple, but you should have 4, one network for everything except the vSwitch

You can see at the bottom if you click a network which it is
Eg

You can also verify by the adapters present in the network

So this is my management network, to name it right click it and go to properties
Here you can also also make sure to allow cluster network communication on this network for the Cluster Heartbeat network, I’d leave this enabled as a backup

iSCSI, this just needs naming, and everything else disabling

Live Migration, this just need cluster communication

Lastly, cluster, this should also only be cluster communication

2.4 – Enabling Live Migration

For this, you’ll want a redundancy NIC team on a separate isolated network thats available in the network list from Failover Cluster Manager

Under the networks section on the left

Click Live Migration Settings on the right

And check the network you have for live migration, I have renamed the networks from the default names to match their use

Then click ok

2.5 – Setting Up The Quorum Drive

First online and initialize the Quorum iSCSI disk with a GPT partition from disk manager

Then add the disk to storage, but do NOT add to cluster shared Volumes, so just click add disk and select the Quorum disk

You can then also re name the drive, I have named mine Quorum

Format it onto a letter, such as D, like so

Then, configure the cluster Quorum settings, buy right clicking the cluster

When going through the wizard, select select the Quorum Witness to manually select the drive

Configure a disk witness

Select the quorum disk you have added earlier

Then click next here to confirm

Then finish

The disk is now showing as assigned to disk witness in quorum, so everything is working as expected here

2.6 – Adding/Changing The Cluster IP

By default when you create a Hyper-V cluster, the cluster IP will be added via DHCP, if you want to change this, or set it static, open failover cluster manager, select the cluster and scroll to Cluster Core Recourses

Click the IP address and then properties on the right

Set the IP static and make sure you have the right network selected, my management is on 10.1.6.0/24

If your network is not selected make sure your management network is on cluster and client

2.7 – Cluster Validation Errors

Here are some solutions to common validation errors when creating the cluster

2.7.1 – The Cluster Network Name Doesnt Have Create Computer Objects Permissions

The error you’ll see for this is

The cluster network name <cluster-name> does not have Create Computer Objects permissions on the Organizational Unit <Ad Path And Details> This can result in issues during the creation of additional network names in this OU.

To fix this you need to give the cluster entry the correct permissions in AD

Go to the location of the Hyper-V servers in AD, for me this is under Lab/Devices/Servers

It will have created an entry for the cluster, mine is called Lab-Cluster
This entry needs special permissions to the OU its in

Open View and Enable Advanced Features

So to fix this, I am going to edit the permissions of the Servers OU
Right click the OU and go to properties

Then security and click advanced

Click Add here, on the bottom left

Select principle

Click object types

Check computers

Add the entry for your cluster my cluster is called Lab-Cluster

Ensure Create Computer Objects, on the bottom left, is selected, ensure it also has read all properties, and to enable to all dependents, ie inheritance

Click ok and apply

2.7.2 – Network Adapter Has RDMA Enabled On The Adapter

Networks that are isolated may give the following error

Network Adapter <Network Name> on Node <host> has RDMA enabled on the adapter, but SMB Client is does not view this adapter as RDMA Enabled

If you do not need RDMA, you can disable this, on my setup, this flagged on the iSCSI, Live Migration And Cluster networks, so we can disable this

You can disable it via PowerShell with
Disable-NetAdapterRdma -Name <Adapter-Name>

2.8 – Add Cluster To WAC (Optional)

Once you have WAC installed you can add a Hyper-V Cluster from the add section

Then select cluster and add

Add the cluster name, this should match to Windows DNS for the cluster IP, and give an admin account if asked

This will also add your Hyper-V hosts, click add

Now the cluster and Hyper-V nodes are showing in WAC

Stage 3 – Setting Up SCVMM (Optional)

This part covers setting up SCVMM, you dont need SCVMM at this point, you can manage your cluster via Failover Cluster manager and WAC, but if you have multiple clusters and have the license for SCVMM this section will walk you through setting it up

3.1 – SCVMM VM Setup

To Deploy VMM you’ll need a dedicated VM with at least 16GB of RAM
Lets create this on one of our Hyper-V hosts, go to the right on the host and select New/Virtual Machine

Select a node

Name the Machine and select the location, you’ll want to use the CSV for this

Select the generation

Add the RAM, you need 16384 as a minimum

Specify the Network

Add a virtual Hard Disk, 128GB should be enough

Add a Windows server ISO

Next, right click the VM and go into Settings
Change the number of CPU cores to 4, the default is 1

Also add an extra disk to the machine for SQL which should be 750GB, go to the VM settings and select the SCSI controller and add a hard disk

Click new to create a new virtual disk

Select dynamically expanding for thin provisioned, or fixed size for thick

Select the disk name and location

And lastly make it 750GB

Right click and start the VM, and then connect to it and install Windows Server

3.2 – Installing Software Prerequisites

Install run the following to download all the exe and msi files to C:\Temp

$tempFolderName = "Temp"
$tempFolder = "C:\" + $tempFolderName +"\"
$itemType = "Directory"
$visualC2017x64Url = "https://aka.ms/vs/17/release/vc_redist.x64.exe"
$visualC2017x64Exe = $tempFolder + "VC_redist.x64.exe"
$msodbcsqlUrl = "https://go.microsoft.com/fwlink/?linkid=2239168"
$msodbcsqlMsi = $tempFolder + "msodbcsql.msi"
$msSqlCmdLnUtilsUrl = "https://go.microsoft.com/fwlink/?linkid=2230791"
$msSqlCmdLnUtilsMsi = $tempFolder + "MsSqlCmdLnUtils.msi"
$adkUrl = "https://go.microsoft.com/fwlink/?linkid=2196127"
$adkExe = $tempFolder + "adksetup.exe"
$adkWinPeUrl = "https://go.microsoft.com/fwlink/?linkid=2196224"
$adkWinPeExe = $tempFolder + "adkwinpesetup.exe"
Invoke-WebRequest -Uri $visualC2017x64Url -OutFile $visualC2017x64Exe
Invoke-WebRequest -Uri $msodbcsqlUrl -OutFile $msodbcsqlMsi
Invoke-WebRequest -Uri $msSqlCmdLnUtilsUrl -OutFile $msSqlCmdLnUtilsMsi
Invoke-WebRequest -Uri $adkUrl -OutFile $adkExe
Invoke-WebRequest -Uri $adkWinPeUrl -OutFile $adkWinPeExe

Then install everything everything thats downloaded

Run the VCresist Exe
VC_redist.x64

Then install the ADKWINPETUP

Specify the location and hit next

Click next here

Click accept here

Then click install

Install the asksetup

Specify the install location

Accept or decline the privacy page

Accept the EULA

Click install

Then install the ODBC setup

Click next here to begin installation

Accept the EULA

Click next here on the defaults

Then install to finish

3.3 – Setting Up The DKM Container

Connect to your DC and open ADSI edit

Right click ADSI edit and go to connect to

Connect to the default naming context

Expand your domain, go to CN=Systsem, right click and create a new object

Create a container and click next

Name the object, eg VMMDKM and click next

Then click finish

Then right click the container, and go to properties

Go to security, then advanced

Click add

Add the VMM service account with full permissions for the container

Then, ok and ok again to apply and close

Go into the properties of the container again, and double click distinguished name

Make a note of this for during the installation
Eg mine is
CN=VMMDKM,CN=System,DC=leaha,DC=co,DC=uk

3.4 – Installing SQL

For VMM 2022, we will be using SQL 2022
Sign into the service account before installing SQL and make sure its in the local administrators group

Mount and open the ISO and run the setup.exe

Click installation

Then click new SQL standalone installation

Enter a product key, you can use the evaluation free license for testing

Accept the EULA

Check using Microsoft update to update SQL

Check the install tests for anything, the warning here is because the windows firewall is enabled, so it will need the to allow the right communication

We can uncheck the Azure extension, unless you explicitly need it

Select the Database Engine Services
Change the instance root directory to the SQL Drive, I have mine mounted on S

Create a named instance and instance ID, these should be the same

Leave the service account as stock, as this is an isolated instance, so it doesnt need a domain service account

Stick with Windows authentication mode and add the VMM/SQL service accounts to have full access

Once you’re happy, click install

Now install the management tools from the ISO by clicking the link

Then scroll down and click the link here to download it

Run the executable

Then click install

When connecting to the DB, make sure you click trust certificate as its self signed

Lastly install the SQL command line utilities from here
Download the x64 version here

Run the executable, then hit next

Accept the EULA

Then install

3.5 – Installing SCVMM

You can download SCVMM from here
Run the executable and click next

Accept the EULA

Set an installation path, I am using C for VMM and S for SQL, then click extract

Then run the setup from the C:\System Centre Virtual Machine Manager

From the install screen, click install

Select both the Management server and the console to install

Add a name and your license key details, entering no key gives you a 180 day trial

Accept the EULA

Click next here

Enable Microsoft Updates

Select an installation location and click next, you may wish to put this on another drive for a production system

As the SQL server is local, the defaults here are fine, assuming you are logged in with the SCVMM service account, if not tick the use following credential box, and enter it, or re log in as that account
Click next

Give the SCVMM service account and password as well as the path for the DKM container from earlier

Leave the ports as default

Specify a library location – for production you ideally want the base install from above on another drive, so this location will change as you dont want it on C

When you are happy click install

3.5.1 – SPN Issues Post Installation

If you get an error about SPN installation after VMM is installed, such as

The Service Principal Name (SPN) could not be registered in Active Directory Domain Services (AD DS) for the VMM management server.

Then you need to run the following as a domain admin
setspn -u -s SCVMM/<MachineBIOSName> <VMMServiceAccount>
setspn -u -s SCVMM/<MachineFQDN> <VMMServiceAccount>

For a cluster, <MachineBIOSName> should be <ClusterBIOSName> and <MachineFQDN> should be <ClusterFQDN>

On the VMM server (or on each node in a cluster), in the registry, navigate to HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Microsoft System Center Virtual Machine Manager Server\Setup.

Set VmmServicePrincipalNames to SCVMM/<MachineBIOSName>,SCVMM/<MachineFQDN>. For a cluster: SCVMM/<ClusterBIOSName>,SCVMM/<ClusterFQDN>

Lastly run
<Install-Path>\setup\ConfigureSCPTool.exe -install
Eg – Where SCVMM is installed to D:\SCVMM
D:\SCVMM\setup\ConfigureSCPTool.exe -install
To configure SCP

3.6 – Updating SCVMM

To patch SCVMM to 2022 Update Rollup 2 you will need to grab the server update here and the console update here

For this guide we will be taking a base SCVMM 2022 install to 2022 Update Rollup 2

First, do the VMM Server update
Double click the CAB file, and right click the msp and extract it, ive extracted it to my downloads

Open PowerShell as an admin and run
msiexec.exe /update <packagename>
Ensuring you have the MSP for the VMM Server as the package, not the CAB file

Click ok here, this will automatically close anything open the update needs closing

Repeat for the console CAB you downloaded, running the msiexec for the MSP

3.7 – Adding A Cluster

Go to fabric on the bottom right, and click add resources

Then Hyper-V hosts and clusters

Then select the top option for Windows servers on the domain

Select specify credentials and give the VMM Service Account, this should be added to the local administrators group on the Hyper-V hosts

Specify the cluster

Check the cluster here, and then click next

Add them to the all hosts group, we can move them later if needed

Click finish

Author

By Leaha

Leave a Reply

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