Delen via


Een gegevensschijf koppelen aan een Windows-VM met PowerShell

Van toepassing op: ✔️ Flexibele schaalsets voor Windows-VM's ✔️

In dit artikel leest u hoe u zowel nieuwe als bestaande schijven koppelt aan een virtuele Windows-machine met behulp van PowerShell.

Bekijk eerst deze tips:

  • De grootte van de virtuele machine bepaalt hoeveel gegevensschijven u kunt koppelen. Zie Grootten voor virtuele machines voor meer informatie.
  • Als u Premium SSD's wilt gebruiken, hebt u een vm-type met Premium-opslag nodig, zoals de virtuele machine uit de DS-serie of de GS-serie.

In dit artikel wordt PowerShell gebruikt in Azure Cloud Shell, dat voortdurend wordt bijgewerkt naar de nieuwste versie. Als u de Cloud Shell wilt openen, selecteert u Probeer het bovenaan een willekeurig codeblok.

Lagere latentie

In bepaalde regio's is de latentie van schijfkoppeling verminderd, dus u ziet een verbetering van maximaal 15%. Dit is handig als u geplande/niet-geplande failovers hebt tussen VM's, u uw workload schaalt of een stateful workload met hoge schaal uitvoert, zoals Azure Kubernetes Service. Deze verbetering is echter beperkt tot de opdracht voor expliciete schijfkoppeling, Add-AzVMDataDisk. U ziet de prestatieverbetering niet als u een opdracht aanroept die impliciet een bijlage kan uitvoeren, zoals Update-AzVM. U hoeft geen andere actie te ondernemen dan het aanroepen van de expliciete bijlageopdracht om deze verbetering te zien.

Lagere latentie is momenteel beschikbaar in elke openbare regio, met uitzondering van:

  • Canada - midden
  • VS - centraal
  • VS - oost
  • VS - oost 2
  • VS - zuid-centraal
  • VS - west 2
  • Duitsland - noord
  • India - west
  • Europa - noord
  • Europa -west

Een lege gegevensschijf toevoegen aan een virtuele machine

In dit voorbeeld ziet u hoe u een lege gegevensschijf toevoegt aan een bestaande virtuele machine.

Beheerde schijven gebruiken

$rgName = 'myResourceGroup'
$vmName = 'myVM'
$location = 'East US'
$storageType = 'Premium_LRS'
$dataDiskName = $vmName + '_datadisk1'

$diskConfig = New-AzDiskConfig -SkuName $storageType -Location $location -CreateOption Empty -DiskSizeGB 128
$dataDisk1 = New-AzDisk -DiskName $dataDiskName -Disk $diskConfig -ResourceGroupName $rgName

$vm = Get-AzVM -Name $vmName -ResourceGroupName $rgName
$vm = Add-AzVMDataDisk -VM $vm -Name $dataDiskName -CreateOption Attach -ManagedDiskId $dataDisk1.Id -Lun 1

Update-AzVM -VM $vm -ResourceGroupName $rgName

Beheerde schijven gebruiken in een beschikbaarheidszone

Als u een schijf in een beschikbaarheidszone wilt maken, gebruikt u New-AzDiskConfig met de -Zone parameter. In het volgende voorbeeld wordt een schijf gemaakt in zone 1.

$rgName = 'myResourceGroup'
$vmName = 'myVM'
$location = 'East US 2'
$storageType = 'Premium_LRS'
$dataDiskName = $vmName + '_datadisk1'

$diskConfig = New-AzDiskConfig -SkuName $storageType -Location $location -CreateOption Empty -DiskSizeGB 128 -Zone 1
$dataDisk1 = New-AzDisk -DiskName $dataDiskName -Disk $diskConfig -ResourceGroupName $rgName

$vm = Get-AzVM -Name $vmName -ResourceGroupName $rgName
$vm = Add-AzVMDataDisk -VM $vm -Name $dataDiskName -CreateOption Attach -ManagedDiskId $dataDisk1.Id -Lun 1

Update-AzVM -VM $vm -ResourceGroupName $rgName

De schijf initialiseren

Nadat u een lege schijf hebt toegevoegd, moet u deze initialiseren. Als u de schijf wilt initialiseren, kunt u zich aanmelden bij een virtuele machine en schijfbeheer gebruiken. Als u WinRM en een certificaat op de virtuele machine hebt ingeschakeld toen u deze hebt gemaakt, kunt u externe PowerShell gebruiken om de schijf te initialiseren. U kunt ook een aangepaste scriptextensie gebruiken:

    $location = "location-name"
    $scriptName = "script-name"
    $fileName = "script-file-name"
    Set-AzVMCustomScriptExtension -ResourceGroupName $rgName -Location $locName -VMName $vmName -Name $scriptName -TypeHandlerVersion "1.4" -StorageAccountName "mystore1" -StorageAccountKey "primary-key" -FileName $fileName -ContainerName "scripts"

Het scriptbestand kan code bevatten om de schijven te initialiseren, bijvoorbeeld:

Notitie

In het voorbeeldscript wordt de PARTITIEstijl MBR gebruikt. Als uw schijf twee tebibytes (TiB) of groter is, moet u GPT-partitionering gebruiken. Als deze onder twee TiB valt, kunt u MBR of GPT gebruiken.

    $disks = Get-Disk | Where partitionstyle -eq 'raw' | sort number

    $letters = 70..89 | ForEach-Object { [char]$_ }
    $count = 0
    $labels = "data1","data2"

    foreach ($disk in $disks) {
        $driveLetter = $letters[$count].ToString()
        $disk |
        Initialize-Disk -PartitionStyle MBR -PassThru |
        New-Partition -UseMaximumSize -DriveLetter $driveLetter |
        Format-Volume -FileSystem NTFS -NewFileSystemLabel $labels[$count] -Confirm:$false -Force
	$count++
    }

Een bestaande gegevensschijf koppelen aan een VIRTUELE machine

U kunt een bestaande beheerde schijf als gegevensschijf aan een virtuele machine koppelen.

$rgName = "myResourceGroup"
$vmName = "myVM"
$dataDiskName = "myDisk"
$disk = Get-AzDisk -ResourceGroupName $rgName -DiskName $dataDiskName

$vm = Get-AzVM -Name $vmName -ResourceGroupName $rgName

$vm = Add-AzVMDataDisk -CreateOption Attach -Lun 0 -VM $vm -ManagedDiskId $disk.Id

Update-AzVM -VM $vm -ResourceGroupName $rgName

Volgende stappen

U kunt ook beheerde schijven implementeren met behulp van sjablonen. Zie Managed Disks gebruiken in Azure Resource Manager-sjablonen of de quickstart-sjabloon voor het implementeren van meerdere gegevensschijven voor meer informatie.