标签:sign otl tin flow ica ceo ada tar isa
摘自:http://www.tech-coffee.net/2-node-hyperconverged-cluster-with-windows-server-2016/
In this part I’ll talk about the implemented hardware and how are connected both nodes. Then I’ll introduce the network design and the required software implementation.
First of all, it is necessary to present you the design. I have bought two nodes that I have built myself. Both nodes are not provided by a manufacturer. Below you can find the hardware that I have implemented in each node:
If I were in production, I’d replace SSD by enterprise grade SSD and I’d add a NVMe SSD for the caching. To finish I’d buy server with two Xeon. Below you can find the hardware implementation.

To support this configuration, I have created five network subnets:
I can’t leverage Simplified SMB MultiChannel because I don’t have a 10GB switch. So each 10GB controller must belong to separate subnets.
I will deploy a Switch Embedded Teaming for 1GB network adapters. I will not implement a Switch Embedded Teaming for 10GB because a switch is missing.
I will have two nodes called pyhyv01 and pyhyv02 (Physical Hyper-V).
The first challenge concerns the failover cluster. Because I have no other physical server, the domain controllers will be virtual. if I implement domain controllers VM in the cluster, how can start the cluster? So the DC VMs must not be in the cluster and must be stored locally. To support high availability, both nodes will host a domain controller locally in the system volume (C:\). In this way, the node boot, the DC VM start and then the failover cluster can start.
Both nodes are deployed in core mode because I really don’t like graphical user interface for hypervisors. I don’t deploy the Nano Server because I don’t like the Current Branch for Business model for Hyper-V and storage usage. The following feature will be deployed for both nodes:

The storage configuration will be easy: I’ll create a unique Storage Pool with all SATA and NVMe SSD. Then I will create two Cluster Shared Volumes that will be distributed across both nodes. The CSV will be called CSV-01 and CSV-02.
I show how to configure a single node. You have to repeat these operations for the second node in the same way. This is why I recommend you to make a script with the commands: the script will help to avoid human errors.
The bios may change regarding the manufacturer and the motherboard. But I always do the same things in each server:
Next I check if the memory is seen, and all storage devices are plugged. When I have time, I run a memtest on server to validate hardware.
I have deployed my nodes from a USB stick configured with Easy2Boot. Once the system is installed, I have deployed drivers for motherboard and for Mellanox network adapters. Because I can’t connect with a remote MMC to Device Manager, I use the following commands to list if drivers are installed:
| 1 2 | gwmi Win32_SystemDriver | select name,@{n="version";e={(gi $_.pathname).VersionInfo.FileVersion}}gwmi Win32_PnPSignedDriver | select devicename,driverversion | 

After all drivers are installed, I configure the server name, the updates, the remote connection and so on. For this, I use sconfig.

This tool is easy, but don’t provide automation. You can do the same thing with PowerShell cmdlet, but I have only two nodes to deploy and I find this easier. All you have to do, is to move in menu and set parameters. Here I have changed the computer name, I have enabled the remote desktop and I have downloaded and installed all updates. I heavily recommend you to install all updates before deploying the Storage Spaces Direct.
Then I configure the power options to “performance” by using the bellow cmdlet:
| 1 | POWERCFG.EXE /S SCHEME_MIN | 
Once the configuration is finished, you can install the required roles and features. You can run the following cmdlet on both nodes:
| 1 | Install-WindowsFeature Hyper-V, Data-Center-Bridging, Failover-Clustering, RSAT-Clustering-Powershell, Hyper-V-PowerShell, Storage-Replica | 
Once you have run this cmdlet the following roles and features are deployed:
Once the OS configuration is finished, you can configure the network. First, I rename network adapters as below:
| 1 2 3 4 5 6 7 | get-netadapter|? Name -notlikevEthernet* |? InterfaceDescription -likeMellanox*#2 | Rename-NetAdapter -NewName Storage-101get-netadapter|? Name -notlikevEthernet* |? InterfaceDescription -likeMellanox*Adapter | Rename-NetAdapter-NewNameStorage-102get-netadapter|? Name -notlikevEthernet* |? InterfaceDescription -likeIntel*#2 | Rename-NetAdapter -NewName Management01-0get-netadapter|? Name -notlikevEthernet* |? InterfaceDescription -likeIntel*Connection | Rename-NetAdapter-NewNameManagement02-0 | 

Next I create the Switch Embedded Teaming with both 1GB network adapters called SW-1G:
| 1 | New-VMSwitch-NameSW-1G-NetAdapterNameManagement01-0, Management02-0-EnableEmbeddedTeaming$True-AllowManagementOS$False | 
Now we can create two virtual network adapters for the management and the heartbeat:
| 1 2 | Add-VMNetworkAdapter-SwitchNameSW-1G-ManagementOS-NameManagement-0Add-VMNetworkAdapter-SwitchNameSW-1G-ManagementOS-NameCluster-100 | 

Then I configure VLAN on vNIC and on storage NIC:
| 1 2 3 | Set-VMNetworkAdapterVLAN-ManagementOS-VMNetworkAdapterNameCluster-100-Access-VlanId100Set-NetAdapter-NameStorage-101-VlanID101-Confirm:$FalseSet-NetAdapter-NameStorage-102-VlanID102-Confirm:$False | 
Below screenshot shows the VLAN configuration on physical and virtual adapters.


Next I disable VM queue (VMQ) on 1GB network adapters and I set it on 10GB network adapters. When I set the VMQ, I use multiple of 2 because hyperthreading is enabled. I start with a base processor number of 2 because it is recommended to leave the first core (core 0) for other processes.
| 1 2 3 4 5 6 7 | Disable-NetAdapterVMQ-NameManagement*# Core 1, 2 & 3 will be used for network traffic on Storage-101Set-NetAdapterRSSStorage-101-BaseProcessorNumber2-MaxProcessors2-MaxProcessorNumber4#Core 4 & 5 will be used for network traffic on Storage-102Set-NetAdapterRSSStorage-102-BaseProcessorNumber6-MaxProcessors2-MaxProcessorNumber8 | 
Next I configure Jumbo Frame on each network adapter.
| 1 | Get-NetAdapterAdvancedProperty-Name*-RegistryKeyword"*jumbopacket"| Set-NetAdapterAdvancedProperty-RegistryValue9014 | 

Now we can enable RDMA on storage NICs:
| 1 | Get-NetAdapter*Storage* | Enable-NetAdapterRDMA | 
The below screenshot is the result of Get-NetAdapterRDMA.

Even if it is useless because I have no switch and other connections on 10GB network adapters, I configure DCB:
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 | # Turn on DCBInstall-WindowsFeature Data-Center-Bridging# Set a policy for SMB-DirectNew-NetQosPolicy"SMB"-NetDirectPortMatchCondition445-PriorityValue8021Action3# Turn on Flow Control for SMBEnable-NetQosFlowControl-Priority3# Make sure flow control is off for other trafficDisable-NetQosFlowControl-Priority0,1,2,4,5,6,7# Apply policy to the target adaptersEnable-NetAdapterQos-InterfaceAlias"Storage-101"Enable-NetAdapterQos-InterfaceAlias"Storage-102"# Give SMB Direct 30% of the bandwidth minimumNew-NetQosTrafficClass"SMB"-Priority3-BandwidthPercentage30-AlgorithmETS | 
Ok, now that network adapters are configured, we can configure IP addresses and try the communication on the network.
| 1 2 3 4 5 6 7 8 9 10 11 12 13 | New-NetIPAddress-InterfaceAlias"vEthernet (Management-0)"-IPAddress10.10.0.5-PrefixLength24-DefaultGateway10.10.0.1-TypeUnicast | Out-NullSet-DnsClientServerAddress-InterfaceAlias"vEthernet (Management-0)"-ServerAddresses10.10.0.20 | Out-NullNew-NetIPAddress-InterfaceAlias"vEthernet (Cluster-100)"-IPAddress10.10.100.5-PrefixLength24-TypeUnicast | Out-NullNew-NetIPAddress-InterfaceAlias"Storage-101"-IPAddress10.10.101.5-PrefixLength24-TypeUnicast | Out-NullNew-NetIPAddress-InterfaceAlias"Storage-102"-IPAddress10.10.102.5-PrefixLength24-TypeUnicast | Out-Null#Disable DNS registration of Storage and Cluster network adapter (Thanks to Philip Elder :))Set-DNSClient-InterfaceAliasStorage*-RegisterThisConnectionsAddress$FalseSet-DNSClient-InterfaceAlias*Cluster*-RegisterThisConnectionsAddress$False | 

Then I try the Jumbo Frame: it is working.

Now my nodes can communicate with other friends through the network. Once you have reproduced these steps on the second node, we can deploy the domain controller.
To make future actions, I work from my laptop with remote PowerShell. To display the Hyper-V VM consoles, I have installed RSAT on my Windows 10. Then I have installed the Hyper-V console:

Before being able to connect to Hyper-V remotely, some configurations are required from the server and client perspectives. In both nodes, run the following cmdlets:
| 1 | Enable-WSManCredSSP-Roleserver | 
In your laptop, run the following cmdlets (replace fqdn-of-hyper-v-host by the future Hyper-V hosts FQDN):
| 1 2 3 4 5 6 7 8 9 | Set-ItemWSMan:\localhost\Client\TrustedHosts-Value"10.10.0.5"Set-ItemWSMan:\localhost\Client\TrustedHosts-Value"fqdn-of-hyper-v-host"Set-ItemWSMan:\localhost\Client\TrustedHosts-Value"10.10.0.6"Set-ItemWSMan:\localhost\Client\TrustedHosts-Value"fqdn-of-hyper-v-host"Enable-WSManCredSSP-Roleclient-DelegateComputer"10.10.0.5"Enable-WSManCredSSP-Roleclient-DelegateComputer"fqdn-of-hyper-v-host"Enable-WSManCredSSP-Roleclient-DelegateComputer"10.10.0.6"Enable-WSManCredSSP-Roleclient-DelegateComputer"fqdn-of-hyper-v-host" | 
Then, run gpedit.msc and configure the following policy:

Now you can leverage the new Hyper-V manager capability which enable to use an alternative credential to connect to Hyper-V.

Before deploying the VM, I have copied the Windows Server 2016 ISO in c:\temp of both nodes. Then I have run the following script from my laptop:
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | # Create the first DC VMEnter-PSSession-ComputerName10.10.0.5-Credentialpyhyv01\administrator$VMName= "VMADS01"# Create Gen 2 VM with dynamic memory, autostart action to 0s and auto stop action set. 2vCPUNew-VM-Generation2-Name$VMName-SwitchNameSW-1G-NoVHD-MemoryStartupBytes2048MB-PathC:\VirtualMachinesSet-VM-Name$VMName-ProcessorCount2-DynamicMemory-MemoryMinimumBytes1024MB-MemoryMaximumBytes4096MB-MemoryStartupBytes2048MB-AutomaticStartActionStart-AutomaticStopActionShutDown-AutomaticStartDelay0-AutomaticCriticalErrorActionNone-CheckpointTypeProduction# Create and add a 60GB dynamic VHDX to the VMNew-VHD-PathC:\VirtualMachines\$VMName\W2016-STD-1.0.vhdx-SizeBytes60GB-DynamicAdd-VMHardDiskDrive-VMName$VMName-PathC:\VirtualMachines\$VMName\W2016-STD-1.0.vhdx# Rename the network adapterGet-VMNetworkAdapter-VMName$VMName| Rename-VMNetworkAdapter-NewNameManagement-0# Add a DVD drive with W2016 ISOAdd-VMDvdDrive-VMName$VMNameSet-VMDvdDrive-VMName$VMName-PathC:\temp\14393.0.160715-1616.RS1_RELEASE_SERVER_EVAL_X64FRE_EN-US.ISO# Set the DVD drive as first boot$VD= Get-VMHardDiskDrive-VMName$VMName-ControllerNumber0-ControllerLocation1Set-VMFirmware-VMName$VMName-FirstBootDevice$VD# Add a data disk to the VM (10GB dynamic)New-VHD-PathC:\VirtualMachines\$VMName\data.vhdx-SizeBytes10GB-DynamicAdd-VMHardDiskDrive-VMName$VMName-PathC:\VirtualMachines\$VMName\Data.vhdx# Start the VMStart-VMExit# Create the second DC VM with the same capabilities as belowEnter-PSSession-ComputerName10.10.0.6-Credentialpyhyv02\administrator$VMName= "VMADS02"New-VM-Generation2-Name$VMName-SwitchNameSW-1G-NoVHD-MemoryStartupBytes2048MB-PathC:\VirtualMachinesSet-VM-Name$VMName-ProcessorCount2-DynamicMemory-MemoryMinimumBytes1024MB-MemoryMaximumBytes4096MB-MemoryStartupBytes2048MB-AutomaticStartActionStart-AutomaticStopActionShutDown-AutomaticStartDelay0-AutomaticCriticalErrorActionNone-CheckpointTypeProductionNew-VHD-PathC:\VirtualMachines\$VMName\W2016-STD-1.0.vhdx-SizeBytes60GB-DynamicAdd-VMHardDiskDrive-VMName$VMName-PathC:\VirtualMachines\$VMName\W2016-STD-1.0.vhdxGet-VMNetworkAdapter-VMName$VMName| Rename-VMNetworkAdapter-NewNameManagement-0Add-VMDvdDrive-VMName$VMNameSet-VMDvdDrive-VMName$VMName-PathC:\temp\14393.0.160715-1616.RS1_RELEASE_SERVER_EVAL_X64FRE_EN-US.ISO$VD= Get-VMHardDiskDrive-VMName$VMName-ControllerNumber0-ControllerLocation1Set-VMFirmware-VMName$VMName-FirstBootDevice$VDNew-VHD-PathC:\VirtualMachines\$VMName\data.vhdx-SizeBytes10GB-DynamicAdd-VMHardDiskDrive-VMName$VMName-PathC:\VirtualMachines\$VMName\Data.vhdxStart-VMExit | 
Once the VMs are created, you can connect to their consoles from Hyper-V manager to install the OS. A better way is to use a sysprep’d image. But because it is a “from scratch” infrastructure, I don’t have a gold master. By using sconfig, you can install updates and enable Remote Desktop. Once the operating systems are deployed, you can connect to the VM across PowerShell Direct.
Below you can find the configuration of the first domain controller:
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 | # Remote connection to first nodeEnter-PSSession-ComputerName10.10.0.5-Credentialpyhyv01\administrator# Establish a PowerShell direct session to VMADS01Enter-PSSession-VMNameVMADS01-CredentialVMADS01\administrator# Rename network adapterRename-NetAdapter-NameEthernet-NewNameManagement-0# Set IP AddressesNew-NetIPAddress-InterfaceAlias"Management-0"-IPAddress10.10.0.20-PrefixLength24-TypeUnicast | Out-Null# Set the DNS (this IP is my DNS server for internet in my lab)Set-DnsClientServerAddress-InterfaceAlias"Management-0"-ServerAddresses10.10.0.229 | Out-Null# Initialize and mount the data diskinitialize-disk-Number1New-Volume-DiskNumber1-FileSystemNTFS-FriendlyNameData-DriveLetterE# Install required featureinstall-WindowsFeature AD-Domain-Services, DNS-IncludeManagementTools# Deploy the forestImport-ModuleADDSDeploymentInstall-ADDSForest `    -CreateDnsDelegation:$false`    -DatabasePath"E:\NTDS"`    -DomainMode"WinThreshold"` #should be soon Win2016    -DomainName"int.HomeCloud.net"`    -DomainNetbiosName"INTHOMECLOUD"`    -ForestMode"WinThreshold"` #should be soon Win2016    -InstallDns:$true`    -LogPath"E:\NTDS"`    -NoRebootOnCompletion:$false`    -SysvolPath"E:\SYSVOL"`    -Force:$true | 
Once the first domain controller is deployed and the forest is ready, you can promote the second domain controller:
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 | Enter-PSSession-ComputerName10.10.0.6-Credentialpyhyv02\administrator# Establish a PowerShell direct session to VMADS02Enter-PSSession-VMNameVMADS02-CredentialVMADS02\administrator# Rename network adapterRename-NetAdapter-NameEthernet-NewNameManagement-0# Set IP AddressesNew-NetIPAddress-InterfaceAlias"Management-0"-IPAddress10.10.0.21-PrefixLength24-TypeUnicast | Out-Null# Set the DNS to the first DCSet-DnsClientServerAddress-InterfaceAlias"Management-0"-ServerAddresses10.10.0.20 | Out-Null# Initialize and mount the data diskinitialize-disk-Number1New-Volume-DiskNumber1-FileSystemNTFS-FriendlyNameData-DriveLetterE# Install required featureinstall-WindowsFeature AD-Domain-Services, DNS-IncludeManagementTools# Deploy the forestImport-ModuleADDSDeploymentInstall-ADDSDomainController `    -NoGlobalCatalog:$false`    -CreateDnsDelegation:$false`    -Credential(Get-Credential) `    -CriticalReplicationOnly:$false`    -DatabasePath"E:\NTDS"`    -DomainName"int.HomeCloud.net"`    -InstallDns:$true`    -LogPath"E:\NTDS"`    -NoRebootOnCompletion:$false`    -SiteName"Default-First-Site-Name"`    -SysvolPath"E:\SYSVOL"`    -Force:$true | 
Once the second server has rebooted, we can configure the directory has below:
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 | Enter-PSSession-computernameVMADS01.int.homecloud.net#Requires -version 4.0$DN= "DC=int,DC=HomeCloud,DC=net"# New Default OUNew-ADOrganizationalUnit-Name"Default"-Path$DN$DefaultDN= "OU=Default,$DN"New-ADOrganizationalUnit-Name"Computers"-Path$DefaultDNNew-ADOrganizationalUnit-Name"Users"-Path$DefaultDN# Redir container to OUcmd /c redircmp "OU=Computers,OU=Default,$DN"cmd /c redirusr "OU=Users,OU=Default,$DN"# Create Accounts treeNew-ADOrganizationalUnit-Name"Accounts"-Path$DN$AccountOU= "OU=Accounts,$DN"New-ADOrganizationalUnit-Name"Users"-Path$AccountOUNew-ADOrganizationalUnit-Name"Groups"-Path$AccountOUNew-ADOrganizationalUnit-Name"Services"-Path$AccountOU# Create Servers treeNew-ADOrganizationalUnit-Name"Servers"-Path$DN$ServersOU= "OU=Servers,$DN"New-ADOrganizationalUnit-Name"Computers"-Path$ServersOUNew-ADOrganizationalUnit-Name"Groups"-Path$ServersOUNew-ADOrganizationalUnit-Name"CNO"-Path$ServersOU# New User‘s groups$GroupAcctOU= "OU=Groups,$AccountOU"New-ADGroup-Name"GG-FabricAdmins"-Path$GroupAcctOU-GroupScopeDomainLocal-Description"Fabric Server‘s administrators"New-ADGroup-Name"GG-SQLAdmins"-Path$GroupAcctOU-GroupScopeDomainLocal-Description"SQL Database‘s administrators"# New Computer‘s groups$GroupCMPOU= "OU=Groups,$ServersOU"New-ADGroup-Name"GG-Hyperv"-Path$GroupCMPOU-GroupScopeDomainLocal-Description"Hyper-V Servers"New-ADGroup-Name"GG-FabricServers"-Path$GroupCMPOU-GroupScopeDomainLocal-Description"Fabric servers"New-ADGroup-Name"GG-SQLServers"-Path$GroupCMPOU-GroupScopeDomainLocal-Description"SQL Servers"Exit | 
Ok, our Active Directory is ready, we can now add Hyper-V nodes to the domain 
To add both nodes to the domain, I run the following cmdlets from my laptop:
| 1 2 3 4 5 6 | Enter-PSSession-ComputerName10.10.0.5-Credentialpyhyv01\administrator$domain= "int.homecloud.net"$password= "P@$$w0rd"| ConvertTo-SecureString-asPlainText-Force$username= "$domain\administrator"$credential= New-ObjectSystem.Management.Automation.PSCredential($username,$password)Add-Computer-DomainName$domain-Credential$credential-OUPath"OU=Computers,OU=Servers,DC=int,DC=HomeCloud,DC=net"-Restart | 
Wait that pyhyv01 has rebooted and run the following cmdlet on pyhyv02. Now you can log on on pyhyv01 and pyhyv02 with domain credential. You can install Domain Services RSAT on the laptop to parse the Active Directory.

Now that the Active Directory is available, we can deploy the cluster. First, I test the cluster to verify that all is ok:
| 1 2 | Enter-PSSession-ComputerNamepyhyv01.int.homecloud.net-credentialinthomecloud\administratorTest-Clusterpyhyv01, pyhyv02-Include"Storage Spaces Direct",Inventory,Network,"System Configuration" | 
Check the report if they are issues with the configuration. If the report is good, run the following cmdlets:
| 1 2 | # Create the clusterNew-Cluster-NameCluster-Hyv01-Nodepyhyv01,pyhyv02-NoStorage-StaticAddress10.10.0.10 | 
Once the cluster is created, I set a Cloud Witness in order that Azure has a vote for the quorum.
| 1 2 | # Add a cloud Witness (require Microsoft Azure account)Set-ClusterQuorum-CloudWitness-ClusterCluster-Hyv01-AccountName"<StorageAccount>"-AccessKey"<AccessKey>" | 
Then I configure the network name in the cluster:
| 1 2 3 4 5 | #Configure network name(Get-ClusterNetwork-Name"Cluster Network 1").Name="Storage-102"(Get-ClusterNetwork-Name"Cluster Network 2").Name="Storage-101"(Get-ClusterNetwork-Name"Cluster Network 3").Name="Cluster-100"(Get-ClusterNetwork-Name"Cluster Network 4").Name="Management-0" | 
Next I configure the Node Fairness to run each time a node is added to the cluster and every 30mn. When the CPU of a node will be utilized at 70%, the node fairness will balance the VM across other nodes.
| 1 2 3 | # Configure Node Fairness(Get-Cluster).AutoBalancerMode = 2(Get-Cluster).AutoBalancerLevel = 2 | 
Then I configure the Fault Domain Awareness to have a fault tolerance based on rack. It is useless in this configuration, but if you add nodes to the cluster, it can be useful. I enable this because it is recommended to make this configuration before enabling Storage Spaces Direct.
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 | # Configure the Fault Domain AwarenessNew-ClusterFaultDomain-TypeSite-Name"Lyon"New-ClusterFaultDomain-TypeRack-Name"Rack-22U-01"New-ClusterFaultDomain-TypeRack-Name"Rack-22U-02"New-ClusterFaultDomain-TypeChassis-Name"Chassis-Fabric-01"New-ClusterFaultDomain-TypeChassis-Name"Chassis-Fabric-02"Set-ClusterFaultDomain-NameLyon-Location"France, Lyon 8e"Set-ClusterFaultDomain-NameRack-22U-01-ParentLyonSet-ClusterFaultDomain-NameRack-22U-02-ParentLyonSet-ClusterFaultDomain-NameChassis-Fabric-01-ParentRack-22U-01Set-ClusterFaultDomain-NameChassis-Fabric-02-ParentRack-22U-02Set-ClusterFaultDomain-Namepyhyv01-ParentChassis-Fabric-01Set-ClusterFaultDomain-Namepyhyv02-ParentChassis-Fabric-02 | 
To finish with the cluster, we have to enable Storage Spaces Direct, and create volume. But before, I run the following script to clean up disks:
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 | icm (Get-Cluster-NameCluster-Hyv01 | Get-ClusterNode) {    Update-StorageProviderCache    Get-StoragePool|? IsPrimordial -eq$false| Set-StoragePool-IsReadOnly:$false-ErrorActionSilentlyContinue    Get-StoragePool|? IsPrimordial -eq$false| Get-VirtualDisk| Remove-VirtualDisk-Confirm:$false-ErrorActionSilentlyContinue    Get-PhysicalDisk| Reset-PhysicalDisk-ErrorActionSilentlyContinue    Get-Disk|? Number -ne$null|? IsBoot -ne$true|? IsSystem -ne$true|? PartitionStyle -neRAW |% {        $_| Set-Disk-isoffline:$false        $_| Set-Disk-isreadonly:$false        $_| Clear-Disk-RemoveData-RemoveOEM-Confirm:$false        $_| Set-Disk-isreadonly:$true        $_| Set-Disk-isoffline:$true    }    Get-Disk|? Number -ne$null|? IsBoot -ne$true|? IsSystem -ne$true|? PartitionStyle -eqRAW | Group-NoElement-PropertyFriendlyName} | Sort-PropertyPsComputerName,Count | 
Now we can enable Storage Spaces Direct and create volumes:
| 1 2 3 4 5 | Enable-ClusterStorageSpacesDirectNew-Volume-StoragePoolFriendlyName"S2D*"-FriendlyNameCSV-01-FileSystemCSVFS_ReFS-Size922GBNew-Volume-StoragePoolFriendlyName"S2D*"-FriendlyNameCSV-02-FileSystemCSVFS_ReFS-Size922GB | 

To finish I rename volume in c:\ClusterStorage by their names in the cluster:
| 1 2 | Rename-Item-PathC:\ClusterStorage\volume1\-NewNameCSV-01Rename-Item-PathC:\ClusterStorage\volume2\-NewNameCSV-02 | 
First, I set default VM and virtual disk folders:
| 1 2 3 4 | Set-VMHOST–computername pyhyv01 –virtualharddiskpath ‘C:\ClusterStorage\CSV-01‘Set-VMHOST–computername pyhyv01 –virtualmachinepath ‘C:\ClusterStorage\CSV-01‘Set-VMHOST–computername pyhyv02 –virtualharddiskpath ‘C:\ClusterStorage\CSV-02‘Set-VMHOST–computername pyhyv02 –virtualmachinepath ‘C:\ClusterStorage\CSV-02‘ | 
Then I configure the Live-Migration protocol and the number of simultaneous migration allowed:
| 1 2 3 4 5 | Enable-VMMigration–Computername pyhyv01, pyhyv02Set-VMHost-MaximumVirtualMachineMigrations4 `           –MaximumStorageMigrations 4 `           –VirtualMachineMigrationPerformanceOption SMB `           -ComputerNamepyhyv01,pyhyv02 | 
Next I add Kerberos delegation to configure Live-Migration in Kerberos mode:
| 1 2 3 4 5 6 7 8 9 10 | Enter-PSSession-ComputerNameVMADS01.int.homecloud.net$HyvHost= "pyhyv01"$Domain= "int.homecloud.net"Get-ADComputerpyhyv02 | Set-ADObject-Add@{"msDS-AllowedToDelegateTo"="Microsoft Virtual System Migration Service/$HyvHost.$Domain", "cifs/$HyvHost.$Domain","Microsoft Virtual System Migration Service/$HyvHost", "cifs/$HyvHost"}$HyvHost= "pyhyv02"Get-ADComputerpyhyv01 | Set-ADObject-Add@{"msDS-AllowedToDelegateTo"="Microsoft Virtual System Migration Service/$HyvHost.$Domain", "cifs/$HyvHost.$Domain","Microsoft Virtual System Migration Service/$HyvHost", "cifs/$HyvHost"}Exit | 
Then I set authentication of Live-Migration to Kerberos.
| 1 2 | Set-VMHost–Computername pyhyv01, pyhyv02 `           –VirtualMachineMigrationAuthenticationType Kerberos | 
Next, I configure the Live-Migration network priority:

To finish I configure the cache size of the CSV to 512MB:
| 1 | (Get-Cluster).BlockCacheSize = 512 | 
Now I’d like to shut down a node to verify if the cluster is always up. Let’s see what happening if I shutdown a node:
As you have seen in the above video, even if I stop a node, the workloads still working. When the second node will be startup again, the virtual disks will enter in Regenerating state but you will be able to access to the data.

You can visualize the storage job with the below cmdlet:

2-node configuration is really a great scenario for small office or branch office. Without the cost of an expansive 10GB switch and a SAN, you can have high availability with Storage Spaces Direct. This kind of cluster is not really hard to deploy but I heavily recommend you to leverage PowerShell to make the implementation. Currently I’m working also on VMware vSAN and I can confirm you that Microsoft has a better solution in 2-nodes configuration. In vSAN scenario, you need a third ESX in a third room. In Microsoft environment, you need only a witness in another room as Microsoft Azure with Cloud Witness.
2-node hyperconverged cluster with Windows Server 2016 (转)
标签:sign otl tin flow ica ceo ada tar isa
原文地址:http://www.cnblogs.com/junjiany/p/7085612.html