Anexar um disco de dados a uma VM do Windows com o PowerShell
Aplica-se a: ✔️ VMs ✔️ do Windows Conjuntos de escala flexíveis
Este artigo mostra como anexar discos novos e existentes a uma máquina virtual do Windows usando o PowerShell.
Primeiro, reveja estas dicas:
- O tamanho da máquina virtual controla quantos discos de dados você pode anexar. Para obter mais informações, consulte Tamanhos para máquinas virtuais.
- Para usar SSDs premium, você precisará de um tipo de VM habilitado para armazenamento premium, como a máquina virtual da série DS ou da série GS.
Este artigo usa o PowerShell no Azure Cloud Shell, que é constantemente atualizado para a versão mais recente. Para abrir o Cloud Shell, selecione Experimentar na parte superior de qualquer bloco de código.
Latência mais baixa
Em regiões selecionadas, a latência de conexão de disco foi reduzida, portanto, você verá uma melhoria de até 15%. Isso é útil se você tiver failovers planejados/não planejados entre VMs, estiver dimensionando sua carga de trabalho ou estiver executando uma carga de trabalho com estado de alta escala, como o Serviço Kubernetes do Azure. No entanto, essa melhoria é limitada ao comando explícito disk attach . Add-AzVMDataDisk
Você não verá a melhoria de desempenho se chamar um comando que pode executar implicitamente uma anexação, como Update-AzVM
. Você não precisa tomar nenhuma ação além de chamar o comando explícito anexar para ver essa melhoria.
Atualmente, a latência mais baixa está disponível em todas as regiões públicas, exceto para:
- Canadá Central
- E.U.A. Central
- E.U.A. Leste
- E.U.A. Leste 2
- E.U.A. Centro-Sul
- E.U.A. Oeste 2
- Norte da Alemanha
- Jio, Oeste da Índia
- Europa do Norte
- Europa Ocidental
Adicionar um disco de dados vazio a uma máquina virtual
Este exemplo mostra como adicionar um disco de dados vazio a uma máquina virtual existente.
Usando discos gerenciados
$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
Usando discos gerenciados em uma zona de disponibilidade
Para criar um disco em uma zona de disponibilidade, use New-AzDiskConfig com o -Zone
parâmetro. O exemplo a seguir cria um disco na zona 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
Inicializar o disco
Depois de adicionar um disco vazio, você precisará inicializá-lo. Para inicializar o disco, você pode entrar em uma VM e usar o gerenciamento de disco. Se você habilitou o WinRM e um certificado na VM quando o criou, poderá usar o PowerShell remoto para inicializar o disco. Você também pode usar uma extensão de script personalizada:
$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"
O arquivo de script pode conter código para inicializar os discos, por exemplo:
Nota
O script de exemplo usa o estilo de partição MBR. Se o disco tiver dois tebibytes (TiB) ou maior, você deverá usar o particionamento GPT. Se estiver abaixo de dois TiB, você pode usar MBR ou GPT.
$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++
}
Anexar um disco de dados existente a uma VM
Você pode anexar um disco gerenciado existente a uma VM como um disco de dados.
$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
Próximos passos
Você também pode implantar discos gerenciados usando modelos. Para obter mais informações, consulte Usando discos gerenciados em modelos do Azure Resource Manager ou o modelo de início rápido para implantar vários discos de dados.