Как создать виртуальную машину Linux с помощью шаблонов Azure Resource Manager
Область применения: ✔️ Виртуальные машины Linux ✔️ Гибкие масштабируемые наборы
Узнайте, как создать виртуальную машину Linux с помощью шаблона Azure Resource Manager и Azure CLI в оболочке Azure Cloud Shell. Сведения о создании виртуальной машины Windows см. в статье Создание виртуальной машины Windows на основе шаблона Resource Manager.
Альтернативным решением будет развертывание шаблона на портале Azure. Чтобы открыть шаблон на портале, нажмите кнопку Развертывание в Azure.
Обзор шаблонов
Шаблоны Azure Resource Manager — это файлы JSON, которые определяют инфраструктуру и конфигурацию решения Azure. Этот шаблон можно использовать, чтобы повторно развертывать решение на протяжении всего его жизненного цикла и гарантировать, что ресурсы развертываются в согласованном состоянии. Дополнительные сведения о формате шаблона и его создании см. в статье Краткое руководство по созданию и развертыванию шаблонов Azure Resource Manager с помощью портала Azure. См. дополнительные сведения о синтаксисе JSON при определении ресурсов в шаблонах Azure Resource Manager.
Шаблон быстрого запуска
Примечание.
Предоставленный шаблон по умолчанию создает виртуальную машину поколения 2 Azure.
Примечание.
Только проверка подлинности SSH включена по умолчанию при использовании шаблона быстрого запуска. При запросе укажите значение собственного открытого ключа SSH, например содержимое ~/.ssh/id_rsa.pub.
Если у вас нет пары ключей SSH, создайте и используйте пару ключей SSH для виртуальных машин Linux в Azure.
Нажмите кнопку " Копировать", чтобы добавить шаблон быстрого запуска в буфер обмена:
{
"$schema": "https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#",
"contentVersion": "1.0.0.0",
"parameters": {
"projectName": {
"type": "string",
"metadata": {
"description": "Specifies a name for generating resource names."
}
},
"location": {
"type": "string",
"defaultValue": "[resourceGroup().location]",
"metadata": {
"description": "Specifies the location for all resources."
}
},
"adminUsername": {
"type": "string",
"metadata": {
"description": "Specifies a username for the Virtual Machine."
}
},
"adminPublicKey": {
"type": "string",
"metadata": {
"description": "Specifies the SSH rsa public key file as a string. Use \"ssh-keygen -t rsa -b 2048\" to generate your SSH key pairs."
}
},
"vmSize": {
"type": "string",
"defaultValue": "Standard_D2s_v3",
"metadata": {
"description": "description"
}
}
},
"variables": {
"vNetName": "[concat(parameters('projectName'), '-vnet')]",
"vNetAddressPrefixes": "10.0.0.0/16",
"vNetSubnetName": "default",
"vNetSubnetAddressPrefix": "10.0.0.0/24",
"vmName": "[concat(parameters('projectName'), '-vm')]",
"publicIPAddressName": "[concat(parameters('projectName'), '-ip')]",
"networkInterfaceName": "[concat(parameters('projectName'), '-nic')]",
"networkSecurityGroupName": "[concat(parameters('projectName'), '-nsg')]",
"networkSecurityGroupName2": "[concat(variables('vNetSubnetName'), '-nsg')]"
},
"resources": [
{
"type": "Microsoft.Network/networkSecurityGroups",
"apiVersion": "2020-05-01",
"name": "[variables('networkSecurityGroupName')]",
"location": "[parameters('location')]",
"properties": {
"securityRules": [
{
"name": "ssh_rule",
"properties": {
"description": "Locks inbound down to ssh default port 22.",
"protocol": "Tcp",
"sourcePortRange": "*",
"destinationPortRange": "22",
"sourceAddressPrefix": "*",
"destinationAddressPrefix": "*",
"access": "Allow",
"priority": 123,
"direction": "Inbound"
}
}
]
}
},
{
"type": "Microsoft.Network/publicIPAddresses",
"apiVersion": "2020-05-01",
"name": "[variables('publicIPAddressName')]",
"location": "[parameters('location')]",
"properties": {
"publicIPAllocationMethod": "Dynamic"
},
"sku": {
"name": "Basic"
}
},
{
"comments": "Simple Network Security Group for subnet [variables('vNetSubnetName')]",
"type": "Microsoft.Network/networkSecurityGroups",
"apiVersion": "2020-05-01",
"name": "[variables('networkSecurityGroupName2')]",
"location": "[parameters('location')]",
"properties": {
"securityRules": [
{
"name": "default-allow-22",
"properties": {
"priority": 1000,
"access": "Allow",
"direction": "Inbound",
"destinationPortRange": "22",
"protocol": "Tcp",
"sourceAddressPrefix": "*",
"sourcePortRange": "*",
"destinationAddressPrefix": "*"
}
}
]
}
},
{
"type": "Microsoft.Network/virtualNetworks",
"apiVersion": "2020-05-01",
"name": "[variables('vNetName')]",
"location": "[parameters('location')]",
"dependsOn": [
"[resourceId('Microsoft.Network/networkSecurityGroups', variables('networkSecurityGroupName2'))]"
],
"properties": {
"addressSpace": {
"addressPrefixes": [
"[variables('vNetAddressPrefixes')]"
]
},
"subnets": [
{
"name": "[variables('vNetSubnetName')]",
"properties": {
"addressPrefix": "[variables('vNetSubnetAddressPrefix')]",
"networkSecurityGroup": {
"id": "[resourceId('Microsoft.Network/networkSecurityGroups', variables('networkSecurityGroupName2'))]"
}
}
}
]
}
},
{
"type": "Microsoft.Network/networkInterfaces",
"apiVersion": "2020-05-01",
"name": "[variables('networkInterfaceName')]",
"location": "[parameters('location')]",
"dependsOn": [
"[resourceId('Microsoft.Network/publicIPAddresses', variables('publicIPAddressName'))]",
"[resourceId('Microsoft.Network/virtualNetworks', variables('vNetName'))]",
"[resourceId('Microsoft.Network/networkSecurityGroups', variables('networkSecurityGroupName'))]"
],
"properties": {
"ipConfigurations": [
{
"name": "ipconfig1",
"properties": {
"privateIPAllocationMethod": "Dynamic",
"publicIPAddress": {
"id": "[resourceId('Microsoft.Network/publicIPAddresses', variables('publicIPAddressName'))]"
},
"subnet": {
"id": "[resourceId('Microsoft.Network/virtualNetworks/subnets', variables('vNetName'), variables('vNetSubnetName'))]"
}
}
}
]
}
},
{
"type": "Microsoft.Compute/virtualMachines",
"apiVersion": "2021-11-01",
"name": "[variables('vmName')]",
"location": "[parameters('location')]",
"dependsOn": [
"[resourceId('Microsoft.Network/networkInterfaces', variables('networkInterfaceName'))]"
],
"properties": {
"hardwareProfile": {
"vmSize": "[parameters('vmSize')]"
},
"osProfile": {
"computerName": "[variables('vmName')]",
"adminUsername": "[parameters('adminUsername')]",
"linuxConfiguration": {
"disablePasswordAuthentication": true,
"ssh": {
"publicKeys": [
{
"path": "[concat('/home/', parameters('adminUsername'), '/.ssh/authorized_keys')]",
"keyData": "[parameters('adminPublicKey')]"
}
]
}
}
},
"storageProfile": {
"imageReference": {
"publisher": "Canonical",
"offer": "0001-com-ubuntu-server-jammy",
"sku": "22_04-lts-gen2",
"version": "latest"
},
"osDisk": {
"createOption": "fromImage"
}
},
"networkProfile": {
"networkInterfaces": [
{
"id": "[resourceId('Microsoft.Network/networkInterfaces', variables('networkInterfaceName'))]"
}
]
}
}
}
]
}
Вы также можете скачать или создать шаблон и указать локальный путь с параметром --template-file
.
Создание виртуальной машины шаблона быстрого запуска с помощью Azure CLI
После получения или создания шаблона быстрого запуска создайте виртуальную машину с ним с помощью Azure CLI.
Следующая команда запрашивает несколько элементов входных данных от пользователя. Например:
- Имя группы ресурсов (resourceGroupName)
- Расположение центра обработки данных Azure, на котором размещена виртуальная машина (расположение)
- Имя ресурсов, связанных с виртуальной машиной (projectName)
- Имя пользователя администратора (имя пользователя)
- Открытый ключ SSH для доступа к терминалу виртуальной машины (ключ)
Для создания виртуальной машины Azure требуется группа ресурсов. Шаблоны быстрого запуска включают создание группы ресурсов в рамках процесса.
Чтобы запустить скрипт CLI, нажмите кнопку Open Cloudshell. Получив доступ к Azure Cloudshell, нажмите кнопку "Копировать ", чтобы скопировать команду, щелкните ее правой кнопкой мыши и выберите " Вставить".
echo "Enter the Resource Group name:" &&
read resourceGroupName &&
echo "Enter the location (i.e. centralus):" &&
read location &&
echo "Enter the project name (used for generating resource names):" &&
read projectName &&
echo "Enter the administrator username:" &&
read username &&
echo "Enter the SSH public key:" &&
read key &&
az group create --name $resourceGroupName --location "$location" &&
az deployment group create --resource-group $resourceGroupName --template-uri https://raw.githubusercontent.com/azure/azure-quickstart-templates/master/quickstarts/microsoft.compute/vm-sshkey/azuredeploy.json --parameters projectName=$projectName adminUsername=$username adminPublicKey="$key" &&
az vm show --resource-group $resourceGroupName --name "$projectName-vm" --show-details --query publicIps --output tsv
В последней строке команды показан общедоступный IP-адрес только что созданной виртуальной машины. Вам потребуется общедоступный IP-адрес для подключения к виртуальной машине.
Подключение к виртуальной машине
После этого можно подключиться по SSH к виртуальной машине в обычном режиме. Укажите собственный общедоступный IP-адрес из предыдущей команды:
ssh <adminUsername>@<ipAddress>
Другие шаблоны
В этом примере вы создали базовую виртуальную машину Linux. Дополнительные шаблоны Resource Manager, включающие платформы приложений или создающие более сложные среды, см. в шаблонах быстрого запуска Azure.
Дополнительные сведения о создании шаблонов, синтаксисе и свойствах JSON для типов ресурсов, которые вы развернули, см. в этих статьях:
- Microsoft.Network/networkSecurityGroups;
- Microsoft.Network/publicIPAddresses
- Microsoft.Network/virtualNetworks;
- Microsoft.Network/networkInterfaces
- Microsoft.Compute/virtualMachines
Следующие шаги
- Чтобы узнать, как создавать шаблоны Resource Manager, ознакомьтесь с документацией по Azure Resource Manager.
- Для просмотра схем виртуальной машины Azure см. справочник по шаблонам Azure.
- Дополнительные примеры шаблонов виртуальных машин см. на странице Шаблоны быстрого запуска Azure.