Delen via


Een Azure Stack HCI-cluster maken met Windows PowerShell

Van toepassing op: Azure Stack HCI, versie 22H2

Belangrijk

Azure Stack HCI maakt nu deel uit van Azure Local. De naam van productdocumentatie wordt nog steeds bijgewerkt. Oudere versies van Azure Stack HCI, bijvoorbeeld 22H2, blijven verwijzen naar Azure Stack HCI en geven de naamwijziging niet weer. Meer informatie.

Waarschuwing

De implementatie-instructies in dit artikel zijn van toepassing op een oudere versie, Azure Stack HCI, versie 22H2. Voor nieuwe implementaties raden we u aan de meest recente algemeen beschikbare versie van Azure Local te gebruiken. Zie Over de lokale implementatie van Azure.

In dit artikel leert u hoe u Windows PowerShell gebruikt om een Hypergeconvergeerd Azure Stack HCI-cluster te maken dat gebruikmaakt van Opslagruimten Direct. Als u liever de wizard Cluster maken in het Windows-beheercentrum gebruikt om het cluster te maken, raadpleegt u Het cluster maken met het Windows-beheercentrum.

Notitie

Als u één serverinstallatie uitvoert van Azure Stack HCI 21H2, gebruikt u PowerShell om het cluster te maken.

U hebt een keuze tussen twee clustertypen:

  • Standaardcluster met één of twee serverknooppunten, allemaal op één site.
  • Stretched cluster met ten minste vier serverknooppunten die zich over twee sites bevinden, met twee knooppunten per site.

Voor het scenario met één server moet u dezelfde instructies voor de ene server voltooien.

Notitie

Stretch-clusters worden niet ondersteund in één serverconfiguratie.

In dit artikel maken we een voorbeeldcluster met de naam Cluster1 dat bestaat uit vier serverknooppunten met de naam Server1, Server2, Server3 en Server4.

Voor het stretched clusterscenario gebruiken we ClusterS1 als de naam en gebruiken we dezelfde vier serverknooppunten die zijn uitgerekt over sites Site1 en Site2.

Zie het overzicht van stretched clusters voor meer informatie over stretched clusters.

Voordat u begint

Voordat u begint, moet u het volgende doen:

  • Lees en begrijp de systeemvereisten van Azure Stack HCI.
  • Lees en begrijp de vereisten voor het fysieke netwerk en hostnetwerkvereisten voor Azure Stack HCI.
  • Installeer het Azure Stack HCI-besturingssysteem op elke server in het cluster. Zie Het Azure Stack HCI-besturingssysteem implementeren.
  • Zorg ervoor dat alle servers zich in de juiste tijdzone bevinden.
  • Een account hebben dat lid is van de lokale groep Administrators op elke server.
  • Rechten hebben in Active Directory om objecten te maken.
  • Voor stretched clusters stelt u uw twee sites vooraf in Active Directory in.

Windows PowerShell gebruiken

U kunt PowerShell lokaal uitvoeren in een RDP-sessie op een hostserver of u kunt PowerShell extern uitvoeren vanaf een beheercomputer. In dit artikel wordt de externe optie besproken.

Wanneer u PowerShell uitvoert vanaf een beheercomputer, neemt u de -Name of -Cluster parameter op met de naam van de server of het cluster dat u beheert. Daarnaast moet u mogelijk de FQDN (Fully Qualified Domain Name) opgeven wanneer u de -ComputerName parameter voor een serverknooppunt gebruikt.

U hebt de RSAT-cmdlets (Remote Server Administration Tools) en PowerShell-modules nodig voor Hyper-V en failoverclustering. Als de cmdlets en modules nog niet beschikbaar zijn in uw PowerShell-sessie op uw beheercomputer, kunt u ze toevoegen met de volgende opdracht: Add-WindowsFeature RSAT-Clustering-PowerShell

Stap 1: de servers instellen

Maak eerst verbinding met elk van de servers, koppel ze aan een domein (hetzelfde domein waarin de beheercomputer zich bevindt) en installeer vereiste rollen en onderdelen.

Stap 1.1: Verbinding maken met de servers

Als u verbinding wilt maken met de servers, moet u eerst een netwerkverbinding hebben, lid zijn van hetzelfde domein of een volledig vertrouwd domein en lokale beheerdersmachtigingen voor de servers hebben.

Open PowerShell en gebruik de volledig gekwalificeerde domeinnaam of het IP-adres van de server waarmee u verbinding wilt maken. U wordt gevraagd om een wachtwoord nadat u de volgende opdracht op elke server hebt uitgevoerd.

In dit voorbeeld gaan we ervan uit dat de servers de naam Server1, Server2, Server3 en Server4 hebben:

Enter-PSSession -ComputerName "Server1" -Credential "Server1\Administrator"

Hier volgt nog een voorbeeld van het doen van hetzelfde:

$myServer1 = "Server1"
$user = "$myServer1\Administrator"

Enter-PSSession -ComputerName $myServer1 -Credential $user

Tip

Wanneer u PowerShell-opdrachten uitvoert vanaf uw beheercomputer, krijgt u mogelijk een foutmelding zoals WinRM kan de aanvraag niet verwerken. U kunt dit oplossen door PowerShell te gebruiken om elke server toe te voegen aan de lijst met vertrouwde hosts op uw beheercomputer. Deze lijst ondersteunt bijvoorbeeld jokertekens Server* .

Set-Item WSMAN:\Localhost\Client\TrustedHosts -Value Server1 -Force

Als u de lijst met vertrouwde hosts wilt weergeven, typt Get-Item WSMAN:\Localhost\Client\TrustedHostsu .

Als u de lijst wilt leegmaken, typt Clear-Item WSMAN:\Localhost\Client\TrustedHostu .

Stap 1.2: Lid worden van het domein en domeinaccounts toevoegen

In de vorige stap hebt u verbinding gemaakt met elk serverknooppunt, het lokale beheerdersaccount <ServerName>\Administrator.

Als u wilt doorgaan, moet u de servers toevoegen aan een domein en het domeinaccount gebruiken dat zich in de lokale groep Administrators op elke server bevindt.

Gebruik de Enter-PSSession cmdlet om verbinding te maken met elke server en voer de volgende cmdlet uit, waarbij u de servernaam, domeinnaam en domeinreferenties vervangt:

Add-Computer -NewName "Server1" -DomainName "contoso.com" -Credential "Contoso\User" -Restart -Force  

Als uw beheerdersaccount geen lid is van de groep Domeinadministrators, voegt u uw beheerdersaccount toe aan de lokale groep Administrators op elke server of nog beter, voegt u de groep toe die u voor beheerders gebruikt. U kunt hiervoor de volgende opdracht gebruiken:

Add-LocalGroupMember -Group "Administrators" -Member "king@contoso.local"

Stap 1.3: Functies en onderdelen installeren

De volgende stap bestaat uit het installeren van vereiste Windows-functies en -onderdelen op elke server voor het cluster. Dit zijn de rollen die moeten worden geïnstalleerd:

  • BitLocker
  • Data Center Bridging
  • Failoverclustering
  • Bestandsserver
  • FS-Gegevensontdubbelingsmodule
  • Hyper-V
  • Hyper-V PowerShell
  • RSAT-Clustering-PowerShell-module
  • RSAT-AD-PowerShell-module
  • NetworkATC
  • NetworkHUD
  • SMB-bandbreedtelimiet
  • Opslagreplica (voor stretched clusters)

Gebruik de volgende opdracht voor elke server (als u via Extern bureaublad bent verbonden, laat u de -ComputerName parameter hier en in de volgende opdrachten weg):

Install-WindowsFeature -ComputerName "Server1" -Name "BitLocker", "Data-Center-Bridging", "Failover-Clustering", "FS-FileServer", "FS-Data-Deduplication", "FS-SMBBW", "Hyper-V", "Hyper-V-PowerShell", "RSAT-AD-Powershell", "RSAT-Clustering-PowerShell", "NetworkATC", "NetworkHUD", "Storage-Replica" -IncludeAllSubFeature -IncludeManagementTools

Als u de opdracht op alle servers in het cluster tegelijk wilt uitvoeren, gebruikt u het volgende script, waarbij u de lijst met variabelen aan het begin aanpast aan uw omgeving:

# Fill in these variables with your values
$ServerList = "Server1", "Server2", "Server3", "Server4"
$FeatureList = "BitLocker", "Data-Center-Bridging", "Failover-Clustering", "FS-FileServer", "FS-Data-Deduplication", "Hyper-V", "Hyper-V-PowerShell", "RSAT-AD-Powershell", "RSAT-Clustering-PowerShell", "NetworkATC", "NetworkHUD", "FS-SMBBW", "Storage-Replica"

# This part runs the Install-WindowsFeature cmdlet on all servers in $ServerList, passing the list of features in $FeatureList.
Invoke-Command ($ServerList) {
    Install-WindowsFeature -Name $Using:Featurelist -IncludeAllSubFeature -IncludeManagementTools
}

Start vervolgens alle servers opnieuw op:

$ServerList = "Server1", "Server2", "Server3", "Server4"
Restart-Computer -ComputerName $ServerList -WSManAuthentication Kerberos

Stap 2: Voorbereiden voor clusterinstallatie

Controleer vervolgens of uw servers gereed zijn voor clustering.

Als een sanity-controle kunt u overwegen de volgende opdrachten uit te voeren om ervoor te zorgen dat uw servers nog niet tot een cluster behoren:

Gebruik Get-ClusterNode dit diagram om alle knooppunten weer te geven:

Get-ClusterNode

Gebruik Get-ClusterResource dit diagram om alle clusterknooppunten weer te geven:

Get-ClusterResource

Gebruik Get-ClusterNetwork dit diagram om alle clusternetwerken weer te geven:

Get-ClusterNetwork

Stap 2.1: Stations voorbereiden

Voordat u Opslagruimten Direct inschakelt, moet u ervoor zorgen dat uw permanente stations leeg zijn. Voer het volgende script uit om oude partities en andere gegevens te verwijderen.

Notitie

Sluit verwijderbare stations die aan een server-knooppunt zijn gekoppeld, uit van het script. Als u dit script bijvoorbeeld lokaal vanaf een serverknooppunt uitvoert, is het geen goed idee om het verwisselbare station dat u gebruikt om het cluster te implementeren, te wissen.

# Fill in these variables with your values
$ServerList = "Server1", "Server2", "Server3", "Server4"

Invoke-Command ($ServerList) {
    Update-StorageProviderCache
    Get-StoragePool | ? IsPrimordial -eq $false | Set-StoragePool -IsReadOnly:$false -ErrorAction SilentlyContinue
    Get-StoragePool | ? IsPrimordial -eq $false | Get-VirtualDisk | Remove-VirtualDisk -Confirm:$false -ErrorAction SilentlyContinue
    Get-StoragePool | ? IsPrimordial -eq $false | Remove-StoragePool -Confirm:$false -ErrorAction SilentlyContinue
    Get-PhysicalDisk | Reset-PhysicalDisk -ErrorAction SilentlyContinue
    Get-Disk | ? Number -ne $null | ? IsBoot -ne $true | ? IsSystem -ne $true | ? PartitionStyle -ne RAW | % {
        $_ | Set-Disk -isoffline:$false
        $_ | Set-Disk -isreadonly:$false
        $_ | Clear-Disk -RemoveData -RemoveOEM -Confirm:$false
        $_ | Set-Disk -isreadonly:$true
        $_ | Set-Disk -isoffline:$true
    }
    Get-Disk | Where Number -Ne $Null | Where IsBoot -Ne $True | Where IsSystem -Ne $True | Where PartitionStyle -Eq RAW | Group -NoElement -Property FriendlyName
} | Sort -Property PsComputerName, Count

Stap 2.2: Clusterconfiguratie testen

Zorg er in deze stap voor dat de serverknooppunten correct zijn geconfigureerd om een cluster te maken. De Test-Cluster cmdlet wordt gebruikt om tests uit te voeren om te controleren of uw configuratie geschikt is om te functioneren als een hypergeconvergeerd cluster. In het volgende voorbeeld wordt de -Include parameter gebruikt, met de specifieke categorieën tests die zijn opgegeven om ervoor te zorgen dat de juiste tests worden opgenomen in de validatie.

Test-Cluster -Node $ServerList -Include "Storage Spaces Direct", "Inventory", "Network", "System Configuration"

Stap 3: het cluster maken

U bent nu klaar om een cluster te maken met de serverknooppunten die u in de voorgaande stappen hebt gevalideerd.

Wanneer u het cluster maakt, krijgt u mogelijk een waarschuwing waarin wordt aangegeven "There were issues while creating the clustered role that may prevent it from starting. For more information, view the report file below." dat u deze waarschuwing veilig kunt negeren. Deze waarschuwing wordt veroorzaakt doordat er geen schijven beschikbaar zijn voor de clusterwitness. De clusterwitness wordt in latere stappen gemaakt.

Notitie

Als de servers statische IP-adressen gebruiken, wijzigt u de volgende opdracht om het statische IP-adres weer te geven door de volgende parameter toe te voegen en het IP-adres op te geven: -StaticAddress <X.X.X.X>;

$ClusterName="cluster1" 
New-Cluster -Name $ClusterName –Node $ServerList –nostorage

Nadat het cluster is gemaakt, kan het enige tijd duren voordat de clusternaam via DNS in uw domein wordt gerepliceerd, met name als werkgroepservers nieuw zijn toegevoegd aan Active Directory. Hoewel het cluster mogelijk wordt weergegeven in het Windows-beheercentrum, is het mogelijk nog niet beschikbaar om verbinding te maken met.

Een goede controle om ervoor te zorgen dat alle clusterbronnen online zijn:

Get-Cluster -Name $ClusterName | Get-ClusterResource

Als het oplossen van het cluster na enige tijd niet lukt, kunt u in de meeste gevallen verbinding maken met behulp van de naam van een van de geclusterde servers in plaats van de clusternaam.

Stap 4: Hostnetwerken configureren

Microsoft raadt het gebruik van Network ATC aan om hostnetwerken te implementeren als u Azure Stack HCI versie 21H2 of hoger gebruikt. Zie anders hostnetwerkvereisten voor specifieke vereisten en informatie.

Netwerk-ATC kan de implementatie van uw beoogde netwerkconfiguratie automatiseren als u een of meer intentietypen voor uw adapters opgeeft. Zie voor meer informatie over specifieke intentietypen: Netwerkverkeerstypen.

Stap 4.1: Fysieke adapters controleren

Voer op een van de clusterknooppunten uit Get-NetAdapter om de fysieke adapters te controleren. Zorg ervoor dat elk knooppunt in het cluster dezelfde benoemde fysieke adapters heeft en dat deze de status 'Up' rapporteren.

Get-NetAdapter -Name pNIC01, pNIC02 -CimSession $ClusterName | Select Name, PSComputerName

Als de naam van een fysieke adapter varieert tussen knooppunten in uw cluster, kunt u de naam ervan wijzigen met behulp van Rename-NetAdapter.

Rename-NetAdapter -Name oldName -NewName newName

Stap 4.2: Een intentie configureren

In dit voorbeeld wordt een intentie gemaakt waarmee de reken- en opslagintentie wordt opgegeven. Zie Hostnetwerken vereenvoudigen met Network ATC voor meer intentievoorbeelden.

Voer de volgende opdracht uit om de typen opslag- en rekenintenties toe te voegen aan pNIC01 en pNIC02. Opmerking: we geven de -ClusterName parameter op.

Add-NetIntent -Name Cluster_ComputeStorage -Compute -Storage -ClusterName $ClusterName -AdapterName pNIC01, pNIC02

De opdracht moet onmiddellijk worden geretourneerd na enige initiële verificatie.

Stap 4.3: Implementatie van intentie valideren

Voer de Get-NetIntent cmdlet uit om de clusterintentie te zien. Als u meer dan één intentie hebt, kunt u de Name parameter opgeven om alleen details van een specifieke intentie weer te geven.

Get-NetIntent -ClusterName $ClusterName

Als u de inrichtingsstatus van de intentie wilt zien, voert u de Get-NetIntentStatus opdracht uit:

Get-NetIntentStatus -ClusterName $ClusterName -Name Cluster_ComputeStorage

Let op de statusparameter met Inrichting, Valideren, Geslaagd, Mislukt.

De status moet binnen een paar minuten zijn geslaagd. Als de successtatus niet optreedt of als er een statusparameterfout optreedt, controleert u de logboeken op problemen.

Notitie

Op dit moment configureert Network ATC geen IP-adressen voor een van de beheerde adapters. Zodra Get-NetIntentStatus de status van de rapporten is voltooid, moet u IP-adressen toevoegen aan de adapters.

Stap 5: Sites instellen (stretched cluster)

Deze taak is alleen van toepassing als u een stretched cluster maakt tussen twee sites met ten minste twee servers op elke site.

Notitie

Als u vooraf Active Directory-sites en -services hebt ingesteld, hoeft u de sites niet handmatig te maken, zoals beschreven in de volgende sectie.

Stap 5.1: Sites maken

In de volgende cmdlet is FaultDomain gewoon een andere naam voor een site. In dit voorbeeld wordt ClusterS1 gebruikt als de naam van het stretched cluster.

New-ClusterFaultDomain -CimSession $ClusterName -FaultDomainType Site -Name "Site1"
New-ClusterFaultDomain -CimSession $ClusterName -FaultDomainType Site -Name "Site2"

Gebruik de Get-ClusterFaultDomain cmdlet om te controleren of beide sites zijn gemaakt voor het cluster.

Get-ClusterFaultDomain -CimSession $ClusterName

Stap 5.2: Serverknooppunten toewijzen

Vervolgens wijzen we de vier serverknooppunten toe aan hun respectieve sites. In het volgende voorbeeld worden Server1 en Server2 toegewezen aan Site1, terwijl Server3 en Server4 zijn toegewezen aan Site2.

Set-ClusterFaultDomain -CimSession $ClusterName -Name "Server1", "Server2" -Parent "Site1"
Set-ClusterFaultDomain -CimSession $ClusterName -Name "Server3", "Server4" -Parent "Site2"

Controleer met behulp van de Get-ClusterFaultDomain cmdlet of de knooppunten zich op de juiste sites bevinden.

Get-ClusterFaultDomain -CimSession $ClusterName

Stap 5.3: Een voorkeurssite instellen

U kunt ook een globale voorkeurssite definiëren, wat betekent dat opgegeven resources en groepen moeten worden uitgevoerd op de voorkeurssite. Deze instelling kan worden gedefinieerd op siteniveau met behulp van de volgende opdracht:

(Get-Cluster).PreferredSite = "Site1"

Het opgeven van een voorkeurssite voor stretched clusters heeft de volgende voordelen:

  • Koude start - tijdens een koude start worden virtuele machines op de voorkeurssite geplaatst

  • Quorumstemmen

    • Met een dynamisch quorum wordt de weging eerst afgenomen van de passieve (gerepliceerde) site om ervoor te zorgen dat de voorkeurssite overleeft als alle andere dingen gelijk zijn. Bovendien worden serverknooppunten eerst van de passieve site verwijderd tijdens het opnieuw groeperen na gebeurtenissen zoals asymmetrische netwerkverbindingsfouten.

    • Tijdens een quorumsplitsing van twee sites, als er geen contact kan worden gemaakt met de clusterwitness, wordt de voorkeurssite automatisch gekozen om te winnen. De serverknooppunten op de passieve site vallen vervolgens af van het clusterlidmaatschap, zodat het cluster een gelijktijdig verlies van stemmen van 50% kan overleven.

De voorkeurssite kan ook worden geconfigureerd op clusterrol- of groepsniveau. In dit geval kan een andere voorkeurssite worden geconfigureerd voor elke virtuele-machinegroep, zodat een site actief en voorkeur heeft voor specifieke virtuele machines.

Stap 5.4: Stretch Clustering instellen met Network ATC

Na versie 22H2 kunt u Network ATC gebruiken om Stretch-clustering in te stellen. Network ATC voegt Stretch toe als een intentietype van versie 22H2. Als u een intentie wilt implementeren met Stretch-clustering met Network ATC, voert u de volgende opdracht uit:

Add-NetIntent -Name StretchIntent -Stretch -AdapterName "pNIC01", "pNIC02"

Een stretch-intentie kan ook worden gecombineerd met andere intenties bij het implementeren met Network ATC.

SiteOverrides

Op basis van stap 5.1-5.3 kunt u uw vooraf gemaakte sites toevoegen aan uw stretch-intentie die is geïmplementeerd met Network ATC. Netwerk-ATC verwerkt dit met behulp van SiteOverrides. Als u een SiteOverride wilt maken, voert u het volgende uit:

 $siteOverride = New-NetIntentSiteOverrides

Zodra uw siteOverride is gemaakt, kunt u elke eigenschap voor de siteOverride instellen. Zorg ervoor dat de naameigenschap van de siteOverride exact dezelfde naam heeft als de naam die uw site heeft in het ClusterFaultDomain. Een niet-overeenkomende naam tussen het ClusterFaultDomain en de siteOverride resulteert erin dat de siteOverride niet wordt toegepast.

De eigenschappen die u voor een bepaalde siteOverride kunt instellen, zijn: Name, StorageVlan en StretchVlan. U maakt bijvoorbeeld 2 siteOverrides voor uw twee sites: site1 en site2 met behulp van:

$siteOverride1 = New-NetIntentSiteOverrides
$siteoverride1.Name = "site1"
$siteOverride1.StorageVLAN = 711
$siteOverride1.StretchVLAN = 25

$siteOverride2 = New-NetIntentSiteOverrides
$siteOverride2.Name = "site2"
$siteOverride2.StorageVLAN = 712
$siteOverride2.StretchVLAN = 26

U kunt in uw PowerShell-venster uitvoeren $siteOverride1$siteOverride2 om ervoor te zorgen dat al uw eigenschappen op de gewenste manier zijn ingesteld.

Als u ten slotte een of meer siteOverrides wilt toevoegen aan uw intentie, voert u het volgende uit:

Add-NetIntent -Name StretchIntent -Stretch -AdapterName "pNIC01" , "pNIC02" -SiteOverrides $siteOverride1, $siteOverride2

Stap 6: Opslagruimten Direct inschakelen

Nadat u het cluster hebt gemaakt, gebruikt u de Enable-ClusterStorageSpacesDirect cmdlet, waarmee Opslagruimten Direct wordt ingeschakeld en doet u het volgende automatisch:

  • Maak een opslaggroep: Hiermee maakt u een opslaggroep voor het cluster met een naam als 'Cluster1-opslaggroep'.

  • Maak een schijf voor de prestatiegeschiedenis van het cluster: hiermee maakt u een virtuele schijf voor clusterprestaties in de opslaggroep.

  • Gegevens- en logboekvolumes maken: hiermee maakt u een gegevensvolume en een logboekvolume in de opslaggroep.

  • Configureer Opslagruimten Direct-caches: als er meer dan één mediatype (station) beschikbaar is voor Opslagruimten Direct, is het in de meeste gevallen het snelst mogelijk als cacheapparaten (lezen en schrijven).

  • Lagen maken: hiermee maakt u twee lagen als standaardlagen. De ene wordt 'Capaciteit' genoemd en de andere 'Prestaties'. De cmdlet analyseert de apparaten en configureert elke laag met de combinatie van apparaattypen en tolerantie.

Voor het scenario met één server is de enige FaultDomainAwarenessDefault PhysicalDisk. Enable-ClusterStorageSpacesDirect cmdlet detecteert één server en configureert faultDomainAwarenessDefault automatisch als een PhysicalDisk tijdens het inschakelen.

Voor stretched clusters zal de Enable-ClusterStorageSpacesDirect cmdlet ook het volgende doen:

  • Controleren of sites zijn ingesteld
  • Bepalen welke knooppunten zich in welke sites bevinden
  • Bepaalt welke opslag elk knooppunt beschikbaar heeft
  • Controleert of de functie Opslagreplica op elk knooppunt is geïnstalleerd
  • Hiermee maakt u een opslaggroep voor elke site en identificeert deze met de naam van de site
  • Hiermee maakt u gegevens en logboekvolumes in elke opslaggroep - één per site

Met de volgende opdracht wordt Opslagruimten Direct ingeschakeld op een cluster met meerdere knooppunten. U kunt ook een beschrijvende naam voor een opslaggroep opgeven, zoals hier wordt weergegeven:

Enable-ClusterStorageSpacesDirect -PoolFriendlyName "$ClusterName Storage Pool" -CimSession $ClusterName

Hier volgt een voorbeeld van het uitschakelen van de opslagcache op een cluster met één knooppunt:

Enable-ClusterStorageSpacesDirect -CacheState Disabled

Gebruik de volgende opdracht om de opslaggroepen weer te geven:

Get-StoragePool -CimSession $ClusterName

Nadat u het cluster hebt gemaakt

Nu uw cluster is gemaakt, zijn er andere belangrijke taken die u moet uitvoeren:

Volgende stappen