Отправка универсального виртуального жесткого диска в Azure для создания новой виртуальной машины
В этом разделе рассматривается отправка универсального неуправляемого диска в учетную запись хранения и создание виртуальной машины на основе отправленного диска. Из универсального образа VHD удалены все сведения вашей личной учетной записи с помощью Sysprep.
Если необходимо создать виртуальную машину из специализированного VHD, расположенного в учетной записи хранения, ознакомьтесь с разделом Создание виртуальной машины на основе специализированного VHD.
В этой статье описывается использование учетных записей хранения, однако мы рекомендуем клиентам использовать вместо них управляемые диски. Полные пошаговые инструкции по подготовке, передаче и созданию виртуальной машины с помощью управляемых дисков приведены в разделе Создание виртуальной машины на основе универсального диска VHD, переданного в Azure, с использованием управляемых дисков.
Подготовка виртуальной машины
Из универсального VHD удалены все данные вашей личной учетной записи с помощью Sysprep. Если вы планируете использовать виртуальный жесткий диск в качестве образа для создания виртуальных машин, то выполните следующие действия:
- Подготовьте виртуальный жесткий диск Windows к передаче в Azure.
- Подготовка виртуальной машины к использованию с помощью Sysprep
Обобщение виртуальной машины Windows с помощью Sysprep
В этом разделе содержатся сведения о том, как обобщить виртуальную машину Windows для ее дальнейшего использования в качестве образа. Помимо прочих действий Sysprep удаляет все сведения о вашей учетной записи и подготавливает машину к использованию в качестве образа. Дополнительные сведения о Sysprep см. в статье How to Use Sysprep: An Introduction (Использование средства Sysprep: введение). статье.
Убедитесь, что Sysprep поддерживает роли сервера, запущенные на компьютере. Дополнительные сведения см. в статье Sysprep Support for Server Roles (Поддержка серверных ролей в Sysprep).
Важно!
Если вы еще не отправили виртуальный жесткий диск в Azure и собираетесь запустить Sysprep первый раз, прежде чем это делать, подготовьте виртуальную машину.
Выполните вход на виртуальную машину Windows.
Откройте окно командной строки с правами администратора. Измените каталог на %windir%\system32\sysprep и запустите файл
sysprep.exe
.В диалоговом окне Программа подготовки системы выберите Переход в окно приветствия системы (OOBE) и убедитесь, что установлен флажок Подготовка к использованию.
В разделе Параметры завершения работы выберите Завершение работы.
Нажмите кнопку ОК.
После выполнения всех необходимых действий Sysprep завершает работу виртуальной машины.
Важно!
Не перезапускайте виртуальную машину до завершения передачи VHD в Azure или создания образа виртуальной машины. Если виртуальная машина случайно будет перезапущена, запустите инструмент Sysprep, чтобы повторно подготовить ее.
Отправка виртуального жесткого диска
Отправьте виртуальный жесткий диск в учетную запись хранения Azure.
Вход в Azure
Если вы еще не установили PowerShell версии 1.4 или выше, то см. статью How to install and configure Azure PowerShell (Установка и настройка Azure PowerShell).
Откройте Azure PowerShell и войдите в свою учетную запись Azure. Откроется всплывающее окно для ввода данных учетной записи Azure.
Connect-AzAccount
Получите идентификаторы доступных вам подписок.
Get-AzSubscription
Укажите соответствующую подписку с помощью идентификатора. Замените
<subscriptionID>
идентификатором правильной подписки.Select-AzSubscription -SubscriptionId "<subscriptionID>"
Получение учетной записи хранения
Вам необходима учетная запись хранения Azure для хранения переданного образа виртуальной машины. Можно использовать существующую учетную запись хранения или создать новую.
Чтобы отобразить список доступных учетных записей хранения, введите:
Get-AzStorageAccount
Если вы хотите использовать существующую учетную запись хранения, перейдите к разделу "Отправка образа виртуальной машины".
Если требуется создать учетную запись хранения, то выполните описанные ниже действия.
Необходимо указать имя группы ресурсов, в которой будет создана учетная запись хранения. Чтобы найти все группы ресурсов, существующие в вашей подписке, введите:
Get-AzResourceGroup
Чтобы создать группу ресурсов с именем myResourceGroup в регионе Западная часть США, введите:
New-AzResourceGroup -Name myResourceGroup -Location "West US"
С помощью командлета New-AzStorageAccount создайте в этой группе ресурсов учетную запись хранения с именем mystorageaccount:
New-AzStorageAccount -ResourceGroupName myResourceGroup -Name mystorageaccount -Location "West US" ` -SkuName "Standard_LRS" -Kind "Storage"
Запуск отправки
Используйте командлет Add-AzVhd, чтобы передать образ в контейнер в учетной записи хранения. В этом примере файл myVHD.vhd передается из расположения "C:\Users\Public\Documents\Virtual hard disks\"
в учетную запись хранения mystorageaccount, входящую в группу ресурсов myResourceGroup. Файл будет помещен в контейнер с именем mycontainer; новое имя файла — 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"
В случае успешного выполнения отобразится ответ, который выглядит следующим образом.
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
В зависимости от сетевого подключения и размера VHD-файла выполнение этой команды может занять некоторое время.
Создание виртуальной машины
Теперь отправленный виртуальный жесткий диск можно использовать для создания новой виртуальной машины.
Указание универсального кода ресурса (URI) диска VHD
Код URI, который должен использовать диск VHD, имеет такой формат: https://mystorageaccount.blob.core.windows.net/mycontainer/MyVhdName.vhd. В этом примере диск VHD с именем myVHD находится в учетной записи хранения mystorageaccount в контейнере mycontainer.
$imageURI = "https://mystorageaccount.blob.core.windows.net/mycontainer/myVhd.vhd"
Создание виртуальной сети
Создайте виртуальную сеть и подсеть виртуальной сети.
Создание подсети. В следующем примере создается подсеть с именем mySubnet в группе ресурсов myResourceGroup с префикс адреса 10.0.0.0/24.
$rgName = "myResourceGroup" $subnetName = "mySubnet" $singleSubnet = New-AzVirtualNetworkSubnetConfig -Name $subnetName -AddressPrefix 10.0.0.0/24
Создание виртуальной сети. В следующем примере создается виртуальная сеть с именем myVnet в расположении западная часть США с префиксом адреса 10.0.0.0/16.
$location = "WestUS" $vnetName = "myVnet" $vnet = New-AzVirtualNetwork -Name $vnetName -ResourceGroupName $rgName -Location $location ` -AddressPrefix 10.0.0.0/16 -Subnet $singleSubnet
Создание общедоступного IP-адреса и сетевого интерфейса
Чтобы обеспечить обмен данными с виртуальной машиной в виртуальной сети, требуются общедоступный IP-адрес и сетевой интерфейс.
Создание общедоступного IP-адреса. В этом примере создается общедоступный IP-адрес с именем myPip.
$ipName = "myPip" $pip = New-AzPublicIpAddress -Name $ipName -ResourceGroupName $rgName -Location $location ` -AllocationMethod Dynamic
Создание сетевой карты. В этом примере создается сетевая карта с именем myNic.
$nicName = "myNic" $nic = New-AzNetworkInterface -Name $nicName -ResourceGroupName $rgName -Location $location ` -SubnetId $vnet.Subnets[0].Id -PublicIpAddressId $pip.Id
Создание группы безопасности сети и правила RDP
Чтобы войти на виртуальную машину с помощью RDP, необходимо настроить правило безопасности, которое разрешает доступ RDP через порт 3389.
В этом примере создается группа безопасности сети с именем myNsg, которая содержит правило с именем myRdpRule, разрешающее трафик RDP через порт 3389. Дополнительные сведения о группах безопасности сети см. в статье Открытие портов для виртуальной машины в Azure с помощью PowerShell.
$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
Создание переменной для виртуальной сети
Создайте переменную для готовой виртуальной сети.
$vnet = Get-AzVirtualNetwork -ResourceGroupName $rgName -Name $vnetName
Создание виртуальной машины
Следующий сценарий PowerShell предназначен для настройки конфигураций виртуальных машин и использования переданного образа виртуальной машины в качестве источника новой установки.
# Enter a new user name and password to use as the local administrator account
# for remotely accessing the VM.
$cred = Get-Credential
# Name of the storage account where the VHD is located. This example sets the
# storage account name as "myStorageAccount"
$storageAccName = "myStorageAccount"
# Name of the virtual machine. This example sets the VM name as "myVM".
$vmName = "myVM"
# Size of the virtual machine. This example creates "Standard_D2_v2" sized VM.
# See the VM sizes documentation for more information:
# https://azure.microsoft.com/documentation/articles/virtual-machines-windows-sizes/
$vmSize = "Standard_D2_v2"
# Computer name for the VM. This examples sets the computer name as "myComputer".
$computerName = "myComputer"
# Name of the disk that holds the OS. This example sets the
# OS disk name as "myOsDisk"
$osDiskName = "myOsDisk"
# Assign a SKU name. This example sets the SKU name as "Standard_LRS"
# Valid values for -SkuName are: Standard_LRS - locally redundant storage, Standard_ZRS - zone redundant
# storage, Standard_GRS - geo redundant storage, Standard_RAGRS - read access geo redundant storage,
# Premium_LRS - premium locally redundant storage.
$skuName = "Standard_LRS"
# Get the storage account where the uploaded image is stored
$storageAcc = Get-AzStorageAccount -ResourceGroupName $rgName -AccountName $storageAccName
# Set the VM name and size
$vmConfig = New-AzVMConfig -VMName $vmName -VMSize $vmSize
#Set the Windows operating system configuration and add the NIC
$vm = Set-AzVMOperatingSystem -VM $vmConfig -Windows -ComputerName $computerName `
-Credential $cred -ProvisionVMAgent -EnableAutoUpdate
$vm = Add-AzVMNetworkInterface -VM $vm -Id $nic.Id
# Create the OS disk URI
$osDiskUri = '{0}vhds/{1}-{2}.vhd' `
-f $storageAcc.PrimaryEndpoints.Blob.ToString(), $vmName.ToLower(), $osDiskName
# Configure the OS disk to be created from the existing VHD image (-CreateOption fromImage).
$vm = Set-AzVMOSDisk -VM $vm -Name $osDiskName -VhdUri $osDiskUri `
-CreateOption fromImage -SourceImageUri $imageURI -Windows
# Create the new VM
New-AzVM -ResourceGroupName $rgName -Location $location -VM $vm
Проверка создания виртуальной машины
После завершения процесса новая виртуальная машина должна отображаться на портале Azure (выберите элементы Обзор>Виртуальные машины). Ее можно также увидеть, выполнив следующие команды PowerShell.
$vmList = Get-AzVM -ResourceGroupName $rgName
$vmList.Name
Дальнейшие действия
Сведения об управлении созданной виртуальной машиной с помощью Azure PowerShell см. в статье Управление виртуальными машинами Azure с помощью Azure Resource Manager и PowerShell.