Управление виртуальными машинами Azure с помощью PowerShell

PowerShell — это очень мощный инструмент, нужно только знать, как его правильно применять. Важно также отметить, что несколько сейчас PowerShell предоставляет функционал больший, чем использование графических элементов управления: всё, что можно выполнить из графического интерфейса, можно реализовать при помощи командлетов PowerShell. Наоборот это правило не работает. В случае с Microsoft Azure с помощью PowerShell вы можете сделать все теже действия, что и через портал управления, кроме создания самой подписки. Применение Azure PowerShell позволяет контролировать и автоматизировать развертывание рабочих нагрузок и управлениями ими. В этой статье мы поговорим о том, как можно использовать Azure PowerShell для управления виртуальными машинами.1qm60rhqfo8pn_c26poviw4z3Установка Azure PowerShell и подключение к подписке Начать следует с установки самого модуля PowerShell для управления Azure. Процесс установки предельно прост. Нужно скачать Microsoft Web Platform Installer, запустить его и установить Microsoft Azure PowerShell с Microsoft Azure SDK. Помимо модулей будет установлена также настроенная консоль Azure PowerShell.mk8h0rxel6k2ssu1gif6rtgf Следующим шагом необходимо подключиться к вашей подписке Azure. Подключение можно осуществить двумя способами: Azure Active Directory. Этот способ аутентификации является рекомендуемым по той причине, что он облегчает процесс управления доступом к вашей подписке Azure. В этом методе вы используете ваш аккаунт Microsoft (или ваш рабочий аккаунт) для входа в систему. Azure Active Directory проверяет данные и возвращает маркер доступа, который и позволит вам управлять вашей подпиской Azure с помощью PowerShell. Сертификат управления. В случае если вы используете сертификат управления, важно помнить, что доступ к вашей подписке с помощью PowerShell будет действителен до тех пор, пока действителен ваш сертификат. Тем не менее, этот метод более сложен в случае управления общим доступом к подписке. Кроме того, Azure Resource Manager API не принимает проверку подлинности сертификата. Далее рассмотрим весь процесс подключения к подписке обоими методами.Совсем забыла сказать. Вы можете использовать Azure PowerShell для того, чтобы управлять подпиской Azure. Но использовать несколько разных PowerShell не всегда удобно. Можно легко импортировать модуль Azure PowerShell в Windows PowerShell. Если вы хотите знать как, загляните под спойлер.

Как импортировать модуль Azure PowerShell в Windows PowerShell Запускаем Windows PowerShell с правами Администратора и используем всего два командлета: Set-ExecutionPolicy RemoteSigned Import-Module «C:\Program Files (x86)\Microsoft SDKs\Azure\PowerShell\ServiceManagement\Azure\Azure.psd1» С помощью первого командлета мы определяем, что все скачанные сценарии PowerShell должны быть подписаны доверенным издателем прежде, чем они будут запущены. Ну, а вторым командлетом мы импортируем модуль Azure PowerShell в Windows PowerShell.w-xd484jv01snrnd3f_s_i99 Azure AD Запускаем консоль Azure PowerShell Запускаем командлет Add-AzureAccount После его выполнения появится окно, в котором нужно будет указать адрес электронной почты, связанный с учетной записью, под которой вы хотите войти в систему1m8bgf8o92q7q6j-0efktzvh6 Далее вам будет необходимо ввести пароль от вашей учетной записи. Azure аутентифицирует вас в системе, сохранит данные для доступа и закроет окно. В PowerShell вы сможете увидеть результат работы командлета: 88-7660uqz968ru3e_8resie Теперь Azure PowerShell успешно подключен к вашей подписке и вы можете приступать к работе.Сертификат управления Зайдите на портал управления Azure и запустите консоль Azure PowerShell В консоли введите командлет: Get-AzurePublishSettingsFile Этот командлет откроет веб-страницу на портале управления Azure, с которой вы сможете загрузить информацию о вашей подписке.Загрузите и сохраните файл »*.publishsettings», в котором содержится сертификат управления. Теперь импортируем файл с помощью командлета Import-AzurePublishSettingsFile C:\Users\\Downloads\-credentials.publishsettings 1ftur2yvhaerk3mdbxcco2hqv На этом процесс подключения Azure PowerShell к вашей подписке завершен, и можно приступать к дальнейшей работе.

Создание виртуальных машин Прежде, чем начать работать с виртуальной машиной в Azure, её нужно создать. Для этого выполним несколько простых шагов.Сначала необходимо установить вашу подписку Azure и аккаунт хранилища. Для того, чтобы узнать имя подписки, используем командлет: Get-AzureSubscription Имя аккаунта хранилища: Get-AzureStorageAccount r2ny7-u7vu6p38uzlo7k-396 Теперь установим: Select-AzureSubscription –SubscriptionName «Visual Studio Ultimate with MSDN» Set-AzureSubscription –SubscriptionName «Visual Studio Ultimate with MSDN» –CurrentStorageAccountName «portalvhdsbs5v2wvyhthcq» 12ctqk2infpd8qlqh7zd815et Теперь необходимо выбрать ImageFamily или значение метки для конкретного образа, соответствующего виртуальной машине Azure, которую вы хотите создать. Вот некоторые примеры образов из галереи Azure Management Portal.1fnw77n7h8mer3tr817z1s2_a Увидеть список доступных образов можно с помощью командлета: Get-AzureVMImage | select ImageFamily –Unique Иногда, имя образа скрыто в свойстве Label, а не в ImageFamily. Поэтому если вы не нашли нужный образ после поиска по ImageFamily, попробуйте запустить следующий командлет: Get-AzureVMImage | select Label -Unique После того, как мы определились с образом, можно приступать к созданию виртуальной машины. Для этого я рекомендую использовать скрипт, хотя можно и вводить команды построчно в обычном Windows PowerShell. $family=«Windows Server 2012 R2 Datacenter» $image=Get-AzureVMImage | where { $_.ImageFamily -eq $family } | sort PublishedDate -Descending | select -ExpandProperty ImageName -First 1 $vmname=«mvademovm» $vmsize=«Small» $availset=«mvademovm_avs» $vm1=New-AzureVMConfig -Name $vmname -InstanceSize $vmsize -ImageName $image -AvailabilitySetName $availset $cred=Get-Credential -Message «Type the name and password of the local administrator account.» $vm1 | Add-AzureProvisioningConfig -Windows -AdminUsername $cred.GetNetworkCredential ().Username -Password $cred.GetNetworkCredential ().Password New-AzureVM –Location «North Europe» -VMs $vm1 Теперь поясню, что же в этом скрипте происходит.Сначала мы указываем имя образа виртуальной машины, которое мы получили при выводе командлета Get-AzureVMImage | select ImageFamily –Unique. С тем же успехом его можно заменить на имя Label. Далее мы выбираем самый последний образ, который имеется в галерее Microsoft Azure из этого семейства образов. $family=«Windows Server 2012 R2 Datacenter» $image=Get-AzureVMImage | where { $_.ImageFamily -eq $family } | sort PublishedDate -Descending | select -ExpandProperty ImageName -First 1 Следующим шагом указываем имя будущей виртуальной машины, выбираем ее размер (выбрать можно из Small, Medium, Large, ExtraLarge, A5, A6, A7, A8, A9), указываем имя группы доступности (availability set). В заключение, на основе все этих свойств мы формируем саму виртуальную машину. $vmname=«mvademovm» $vmsize=«Small» $availset=«mvademovm_avs» $vm1=New-AzureVMConfig -Name $vmname -InstanceSize $vmsize -ImageName $image -AvailabilitySetName $availset Далее мы указываем логин и пароль для локального администратора: $cred=Get-Credential -Message «Type the name and password of the local administrator account.» $vm1 | Add-AzureProvisioningConfig -Windows -AdminUsername $cred.GetNetworkCredential ().Username -Password $cred.GetNetworkCredential ().Password При выполнении скрипта появится окно, в котором мы должны будем ввести логин и пароль: h5rtu0zn__kh_xw7w7umy9ct Наконец, с помощью последнего командлета, мы создаем новую виртуальную машину в новой облачной службе: New-AzureVM –Location «North Europe» -VMs $vm1 Мы указываем желаемую локацию и можем выбирать из Central US, East US, East US 2, South Central US, West US, North Europe, West Europe, East Asia, Southeast Asia, Japan West, Japan East.Также при запуске этого командлета нужно будет ввести имя для создаваемой облачной службы. Ждем несколько минут, и виртуальная машина Azure готова! 7tqu286gzwt8n8332_3ng02g Эту же виртуальную машину мы можем увидеть и портале: --qbmd75-tj88p0_wj8kmeyn Включение, выключение, удаление Если создание виртуальной машины требует определенной последовательности шагов, то для ее удаления достаточно всего лишь одного командлета: Remove-AzureVM -ServiceName «mvademovm» -Name «mvademovm» -DeleteVHD Одной из ситуаций, когда удобнее использовать Azure PowerShell для управления виртуальной машиной, чем заходить на Azure Management Portal, является включение и выключение. Задача эта решается двумя скриптами: запуск виртуальной машины

Start-AzureVM -ServiceName «mvademovm» -Name «mvademovm» выключение виртуальной машины Stop-AzureVM -ServiceName «mvademovm» -Name «mvademovm» -Force Основные примеры управления виртуальными машинами с помощью Microsoft Azure мы рассмотрели. С подробным списком командлетов Azure PowerShell вы можете ознакомиться здесь.Надеюсь, информация в этой статье будет вам полезна! Удачи в применение PowerShell для настройки ваших систем!

Полезные ссылки

© Habrahabr.ru