Sdílet prostřednictvím


Vytvoření virtuálního počítače s Linuxem pomocí šablon Azure Resource Manageru

Platí pro: ✔️ Flexibilní škálovací sady virtuálních počítačů s Linuxem ✔️

Zjistěte, jak vytvořit virtuální počítač s Linuxem pomocí šablony Azure Resource Manageru a Azure CLI z Azure Cloud Shellu. Pokud chcete vytvořit virtuální počítač s Windows, přečtěte si téma Vytvoření virtuálního počítače s Windows ze šablony Resource Manageru.

Alternativou je nasazení šablony z webu Azure Portal. Pokud chcete šablonu otevřít na portálu, vyberte tlačítko Nasadit do Azure .

Button to deploy the Resource Manager template to Azure.

Přehled šablon

Šablony Azure Resource Manageru jsou soubory JSON, které definují infrastrukturu a konfiguraci vašeho řešení Azure. Pomocí šablony můžete řešení opakovaně nasadit v průběhu životního cyklu a mít přitom jistotu, že se prostředky nasadí konzistentně. Další informace o formátu šablony a jejím vytvoření najdete v tématu Rychlý start: Vytvoření a nasazení šablon Azure Resource Manageru pomocí webu Azure Portal. Syntaxi JSON pro typy prostředků najdete v tématu Definování prostředků v šablonách Azure Resource Manageru.

Šablona pro rychlý start

Poznámka:

Zadaná šablona ve výchozím nastavení vytvoří virtuální počítač Azure Generation 2.

Poznámka:

Při použití šablony pro rychlý start je ve výchozím nastavení povolené pouze ověřování SSH. Po zobrazení výzvy zadejte hodnotu vlastního veřejného klíče SSH, například obsah ~/.ssh/id_rsa.pub.

Pokud pár klíčů SSH nemáte, vytvořte a použijte pár klíčů SSH pro virtuální počítače s Linuxem v Azure.

Kliknutím na Kopírovat přidáte šablonu rychlého startu do schránky:

{
  "$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'))]"
            }
          ]
        }
      }
    }
  ]
}

Můžete si také stáhnout nebo vytvořit šablonu a zadat místní cestu pomocí parametru --template-file .

Vytvoření virtuálního počítače šablony pro rychlý start pomocí Azure CLI

Po získání nebo vytvoření šablony rychlého startu vytvořte virtuální počítač s ním pomocí Azure CLI.

Následující příkaz vyžaduje od uživatele několik částí vstupu. Tady jsou některé z nich:

  • Název skupiny prostředků (resourceGroupName)
  • Umístění datacentra Azure, které hostuje virtuální počítač (umístění)
  • Název prostředků souvisejících s virtuálním počítačem (název_projektu)
  • Uživatelské jméno pro uživatele správce (uživatelské jméno)
  • Veřejný klíč SSH pro přístup k terminálu virtuálního počítače (klíč)

Vytvoření virtuálního počítače Azure vyžaduje skupinu prostředků. Šablony rychlého startu zahrnují vytvoření skupiny prostředků v rámci procesu.

Pokud chcete spustit skript rozhraní příkazového řádku, klikněte na Otevřít CloudShell. Jakmile budete mít přístup k Azure CloudShellu, klikněte na Kopírovat a zkopírujte příkaz, klikněte pravým tlačítkem myši na prostředí a pak vyberte Vložit.

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

Poslední řádek v příkazu zobrazuje veřejnou IP adresu nově vytvořeného virtuálního počítače. K připojení k virtuálnímu počítači potřebujete veřejnou IP adresu.

Připojení k virtuálnímu počítači

K virtuálnímu počítači pak můžete použít SSH jako obvykle. Zadejte vlastní veřejnou IP adresu z předchozího příkazu:

ssh <adminUsername>@<ipAddress>

Další šablony

V tomto příkladu jste vytvořili základní virtuální počítač s Linuxem. Další šablony Resource Manageru, které zahrnují aplikační architektury nebo vytvářejí složitější prostředí, najdete v šablonách Azure Pro rychlý start.

Další informace o vytváření šablon najdete v syntaxi JSON a vlastnostech pro typy prostředků, které jste nasadili:

Další kroky

  • Informace o vývoji šablon Resource Manageru najdete v dokumentaci k Azure Resource Manageru.
  • Pokud chcete zobrazit schémata virtuálních počítačů Azure, přečtěte si referenční informace k šablonám Azure.
  • Další ukázky šablon virtuálních počítačů najdete v šablonách Azure Pro rychlý start.