Nota
O acesso a esta página requer autorização. Pode tentar iniciar sessão ou alterar os diretórios.
O acesso a esta página requer autorização. Pode tentar alterar os diretórios.
Crie uma nova VM anexando um disco não gerenciado especializado como o disco do sistema operacional usando o Powershell. Um disco especializado é uma cópia do VHD de uma VM existente que mantém as contas de usuário, aplicativos e outros dados de estado da VM original.
Tem duas opções:
Opção 1: Carregar um VHD especializado
Você pode carregar o VHD de uma VM especializada criada com uma ferramenta de virtualização local, como o Hyper-V, ou de uma VM exportada de outra nuvem.
Preparar a VM
Você pode carregar um VHD especializado que foi criado usando uma VM local ou um VHD exportado de outra nuvem. Um VHD especializado mantém as contas de usuário, aplicativos e outros dados de estado da sua VM original. Se você pretende usar o VHD as-is para criar uma nova VM, verifique se as etapas a seguir foram concluídas.
- Preparar um VHD do Windows para carregar no Azure. Não generalize a VM usando o Sysprep.
- Remova todas as ferramentas de virtualização convidada e agentes instalados na VM (ou seja, ferramentas VMware).
- Verifique se a VM está configurada para extrair seu endereço IP e configurações de DNS via DHCP. Isso garante que o servidor obtenha um endereço IP dentro da VNet ao iniciar.
Obter a conta de armazenamento
Você precisa de uma conta de armazenamento no Azure para armazenar a imagem da VM carregada. Você pode usar uma conta de armazenamento existente ou criar uma nova.
Para mostrar as contas de armazenamento disponíveis, digite:
Get-AzStorageAccount
Se você quiser usar uma conta de armazenamento existente, vá para a seção Carregar a imagem da VM.
Se você precisar criar uma conta de armazenamento, siga estas etapas:
Você precisa do nome do grupo de recursos onde a conta de armazenamento deve ser criada. Para descobrir todos os grupos de recursos que estão na sua assinatura, digite:
Get-AzResourceGroupPara criar um grupo de recursos chamado myResourceGroup na região Oeste dos EUA, digite:
New-AzResourceGroup -Name myResourceGroup -Location "West US"Crie uma conta de armazenamento chamada mystorageaccount neste grupo de recursos usando o cmdlet New-AzStorageAccount:
New-AzStorageAccount -ResourceGroupName myResourceGroup -Name mystorageaccount -Location "West US" ` -SkuName "Standard_LRS" -Kind "Storage"
Carregue o VHD para a sua conta de armazenamento
Use o cmdlet Add-AzVhd para carregar a imagem em um contêiner em sua conta de armazenamento. Este exemplo carrega o arquivo myVHD.vhd do "C:\Users\Public\Documents\Virtual hard disks\" para uma conta de armazenamento chamada mystorageaccount no grupo de recursos myResourceGroup. O arquivo será colocado no contêiner chamado mycontainer e o novo nome do arquivo será myUploadedVHD.vhd.
$rgName = "myResourceGroup"
$urlOfUploadedImageVhd = "https://mystorageaccount.blob.core.windows.net/mycontainer/myUploadedVHD.vhd"
Add-AzVhd -ResourceGroupName $rgName -Destination $urlOfUploadedImageVhd `
-LocalFilePath "C:\Users\Public\Documents\Virtual hard disks\myVHD.vhd"
Se for bem-sucedido, você receberá uma resposta semelhante a esta:
MD5 hash is being calculated for the file C:\Users\Public\Documents\Virtual hard disks\myVHD.vhd.
MD5 hash calculation is completed.
Elapsed time for the operation: 00:03:35
Creating new page blob of size 53687091712...
Elapsed time for upload: 01:12:49
LocalFilePath DestinationUri
------------- --------------
C:\Users\Public\Doc... https://mystorageaccount.blob.core.windows.net/mycontainer/myUploadedVHD.vhd
Dependendo da sua ligação de rede e do tamanho do ficheiro VHD, este comando poderá demorar algum tempo a concluir.
Opção 2: Copiar o VHD de uma VM do Azure existente
Você pode copiar um VHD para outra conta de armazenamento para usar ao criar uma nova VM duplicada.
Antes de começar
Certifique-se de que:
- Tenha informações sobre as contas de armazenamento de origem e de destino. Para a VM de origem, você precisa ter a conta de armazenamento e os nomes de contêiner. Normalmente, o nome do contêiner será vhds. Você também precisa ter uma conta de armazenamento de destino. Se ainda não tiver uma, pode criá-la usando o portal (All Services> contas Storage > Add) ou utilizando o cmdlet New-AzStorageAccount.
- Ter baixado e instalado a ferramenta AzCopy.
Desalocar a máquina virtual
Desatribua a VM, o que libera o VHD para ser copiado.
- Portal: Clique Máquinas virtuais>myVM> Parar
- Powershell: Use Stop-AzVM para parar (dealocar) a VM chamada myVM no grupo de recursos myResourceGroup.
Stop-AzVM -ResourceGroupName myResourceGroup -Name myVM
O Status da VM no portal do Azure muda de Interrompido para Interrompido (dealocado).
Obter os URLs da conta de armazenamento
Você precisa das URLs das contas de armazenamento de origem e destino. Os URLs têm a seguinte aparência: https://<storageaccount>.blob.core.windows.net/<containerName>/. Se você já sabe a conta de armazenamento e o nome do contêiner, basta substituir as informações entre colchetes para criar sua URL.
Você pode usar o portal do Azure ou o Azure Powershell para obter a URL:
- Portal: Clique no > para Todos os serviços>Contas de armazenamento>conta de armazenamento>Blobs e seu arquivo VHD de origem provavelmente está no contêiner vhds. Clique em Propriedades do contêiner e copie o texto rotulado URL. Você precisará das URLs dos contêineres de origem e destino.
- Powershell: Use Get-AzVM para obter as informações da VM chamada myVM no grupo de recursos myResourceGroup. Nos resultados, procure na seção perfil de armazenamento para o Uri Vhd. A primeira parte do URI é a URL para o contentor e a última parte é o nome VHD do sistema operativo para a Máquina Virtual.
Get-AzVM -ResourceGroupName "myResourceGroup" -Name "myVM"
Obter as chaves de acesso de armazenamento
Encontre as chaves de acesso para as contas de armazenamento de origem e destino. Para obter mais informações sobre chaves de acesso, consulte Sobre contas de armazenamento do Azure.
- Portal: Clique Todos os serviços>Contas de armazenamento>conta de armazenamento>Chaves de acesso. Copie a chave rotulada como key1.
- Powershell: Utilize Get-AzStorageAccountKey para recolher a chave de armazenamento para a conta de armazenamento mystorageaccount no grupo de recursos myResourceGroup. Copie a tecla marcada como key1.
Get-AzStorageAccountKey -Name mystorageaccount -ResourceGroupName myResourceGroup
Copiar o VHD
Você pode copiar arquivos entre contas de armazenamento usando AzCopy. Para o contêiner de destino, se o contêiner especificado não existir, ele será criado para você.
Para usar o AzCopy, abra um prompt de comando em sua máquina local e navegue até a pasta onde o AzCopy está instalado. Será semelhante a C:\Program Files (x86)\Microsoft SDKs\Azure\AzCopy.
Para copiar todos os arquivos dentro de um contêiner, use a opção /S. Isso pode ser usado para copiar o VHD do SO e todos os discos de dados se eles estiverem no mesmo contêiner. Este exemplo mostra como copiar todos os ficheiros do contêiner mysourcecontainer na conta de armazenamento mysourcestorageaccount para o contêiner mydestinationcontainer na conta de armazenamento mydestinationstorageaccount. Substitua os nomes das contas de armazenamento e contêineres pelos seus próprios. Substitua <sourceStorageAccountKey1> e <destinationStorageAccountKey1> por suas próprias chaves.
AzCopy /Source:https://mysourcestorageaccount.blob.core.windows.net/mysourcecontainer `
/Dest:https://mydestinationatorageaccount.blob.core.windows.net/mydestinationcontainer `
/SourceKey:<sourceStorageAccountKey1> /DestKey:<destinationStorageAccountKey1> /S
Se você quiser copiar apenas um VHD específico em um contêiner com vários arquivos, também poderá especificar o nome do arquivo usando a opção /Pattern. Neste exemplo, somente o arquivo chamado myFileName.vhd será copiado.
AzCopy /Source:https://mysourcestorageaccount.blob.core.windows.net/mysourcecontainer `
/Dest:https://mydestinationatorageaccount.blob.core.windows.net/mydestinationcontainer `
/SourceKey:<sourceStorageAccountKey1> /DestKey:<destinationStorageAccountKey1> `
/Pattern:myFileName.vhd
Quando terminar, você receberá uma mensagem que se parece com:
Finished 2 of total 2 file(s).
[2016/10/07 17:37:41] Transfer summary:
-----------------
Total files transferred: 2
Transfer successfully: 2
Transfer skipped: 0
Transfer failed: 0
Elapsed time: 00.00:13:07
Solução de problemas
- Quando você usa AZCopy, se você vir o erro "O servidor falhou ao autenticar a solicitação", certifique-se de que o valor do cabeçalho de autorização está formado corretamente, incluindo a assinatura. Se você estiver usando a chave 2 ou a chave de armazenamento secundária, tente usar a chave de armazenamento primária ou a 1ª chave de armazenamento.
Criar a nova VM
Você precisa criar rede e outros recursos de VM para serem usados pela nova VM.
Criar a subnet e a vnet
Crie a vNet e a subNet da rede virtual .
Crie a sub-rede. Este exemplo cria uma sub-rede chamada mySubNet, no grupo de recursos myResourceGroup, e define o prefixo do endereço da sub-rede como 10.0.0.0/24.
$rgName = "myResourceGroup" $subnetName = "mySubNet" $singleSubnet = New-AzVirtualNetworkSubnetConfig -Name $subnetName -AddressPrefix 10.0.0.0/24Crie a rede virtual (vNet). Este exemplo define o nome da rede virtual como myVnetName, o local como West USe o prefixo de endereço da rede virtual como 10.0.0.0/16.
$location = "West US" $vnetName = "myVnetName" $vnet = New-AzVirtualNetwork -Name $vnetName -ResourceGroupName $rgName -Location $location ` -AddressPrefix 10.0.0.0/16 -Subnet $singleSubnetCriar o grupo de segurança de rede e uma regra RDP
Para poder fazer login na sua VM usando RDP, você precisa ter uma regra de segurança que permita o acesso RDP na porta 3389. Como o VHD para a nova VM foi criado a partir de uma VM especializada existente, depois que a VM é criada, você pode usar uma conta existente da máquina virtual de origem que tinha permissão para fazer logon usando RDP. Isso precisa ser concluído antes de criar a interface de rede à qual será associado.
Este exemplo define o nome NSG como myNsg e o nome da regra RDP como myRdpRule.
$nsgName = "myNsg"
$rdpRule = New-AzNetworkSecurityRuleConfig -Name myRdpRule -Description "Allow RDP" `
-Access Allow -Protocol Tcp -Direction Inbound -Priority 110 `
-SourceAddressPrefix Internet -SourcePortRange * `
-DestinationAddressPrefix * -DestinationPortRange 3389
$nsg = New-AzNetworkSecurityGroup -ResourceGroupName $rgName -Location $location `
-Name $nsgName -SecurityRules $rdpRule
Para obter mais informações sobre pontos de extremidade e regras NSG, consulte Abrindo portas para uma VM no Azure usando o PowerShell.
Criar um endereço IP público e uma NIC
Para habilitar a comunicação com a máquina virtual na rede virtual, necessita de um de endereço IP público e uma interface de rede.
Crie o IP público. Neste exemplo, o nome do endereço IP público é definido como myIP.
$ipName = "myIP" $pip = New-AzPublicIpAddress -Name $ipName -ResourceGroupName $rgName -Location $location ` -AllocationMethod DynamicCrie a NIC. Neste exemplo, o nome da NIC é definido como myNicName. Esta etapa também associa o Grupo de Segurança de Rede criado anteriormente a esta NIC.
$nicName = "myNicName" $nic = New-AzNetworkInterface -Name $nicName -ResourceGroupName $rgName ` -Location $location -SubnetId $vnet.Subnets[0].Id -PublicIpAddressId $pip.Id -NetworkSecurityGroupId $nsg.Id
Definir o nome e o tamanho da VM
Este exemplo define o nome da VM como "myVM" e o tamanho da VM como "Standard_A2".
$vmName = "myVM"
$vmConfig = New-AzVMConfig -VMName $vmName -VMSize "Standard_A2"
Adicionar a NIC
$vm = Add-AzVMNetworkInterface -VM $vmConfig -Id $nic.Id
Configurar o disco do SO
Defina o URI para o VHD que você carregou ou copiou. Neste exemplo, o arquivo VHD chamado myOsDisk.vhd é mantido em uma conta de armazenamento chamada myStorageAccount em um contêiner chamado myContainer.
$osDiskUri = "https://myStorageAccount.blob.core.windows.net/myContainer/myOsDisk.vhd"Adicione o disco do SO. Neste exemplo, quando o disco do sistema operacional é criado, o termo "osDisk" é anexado ao nome da VM para criar o nome do disco do sistema operacional. Este exemplo também especifica que esse VHD baseado no Windows deve ser anexado à VM como o disco do sistema operacional.
$osDiskName = $vmName + "osDisk" $vm = Set-AzVMOSDisk -VM $vm -Name $osDiskName -VhdUri $osDiskUri -CreateOption attach -Windows
Opcional: Se você tiver discos de dados que precisam ser anexados à VM, adicione os discos de dados usando as URLs de VHDs de dados e o número de unidade lógica (Lun) apropriado.
$dataDiskName = $vmName + "dataDisk"
$vm = Add-AzVMDataDisk -VM $vm -Name $dataDiskName -VhdUri $dataDiskUri -Lun 1 -CreateOption attach
Ao usar uma conta de armazenamento, os URLs de disco de dados e do sistema operacional têm a seguinte aparência: https://StorageAccountName.blob.core.windows.net/BlobContainerName/DiskName.vhd. Você pode encontrar isso no portal navegando até o contêiner de armazenamento de destino, clicando no sistema operacional ou no VHD de dados que foi copiado e, seguidamente, copiando o conteúdo do URL.
Conclua a VM
Crie a VM usando as configurações que acabamos de criar.
#Create the new VM
New-AzVM -ResourceGroupName $rgName -Location $location -VM $vm
Se esse comando tiver sido bem-sucedido, você verá uma saída como esta:
RequestId IsSuccessStatusCode StatusCode ReasonPhrase
--------- ------------------- ---------- ------------
True OK OK
Verifique se a VM foi criada
Você verá a VM recém-criada no portal do Azure, em Todos os serviços>Máquinas virtuaisou usando os seguintes comandos do PowerShell:
$vmList = Get-AzVM -ResourceGroupName $rgName
$vmList.Name
Próximos passos
Inicie sessão na sua nova máquina virtual. Para obter mais informações, consulte Como se conectar e fazer logon em uma máquina virtual do Azure executando o Windows.