如何使用 Azure Resource Manager 範本建立 Linux 虛擬機
適用於:✔️ Linux VM ✔️ 彈性擴展集
瞭解如何使用 Azure Resource Manager 範本和 Azure CLI 從 Azure Cloud Shell 建立 Linux 虛擬機(VM)。 若要建立 Windows 虛擬機,請參閱 從 Resource Manager 範本建立 Windows 虛擬機。
替代方法是從 Azure 入口網站 部署範本。 若要在入口網站中開啟範本,請選取 [ 部署至 Azure ] 按鈕。
範本概觀
Azure Resource Manager 範本是 JSON 檔案,可定義 Azure 解決方案的基礎結構和組態。 藉由使用範本,您可以在整個生命週期中重複部署解決方案,並確信您的資源會以一致的狀態部署。 若要深入瞭解範本的格式和建構方式,請參閱快速入門:使用 Azure 入口網站 建立及部署 Azure Resource Manager 範本。 若要檢視資源類型的 JSON 語法,請參閱 在 Azure Resource Manager 範本中定義資源。
快速入門範本
注意
提供的範本預設會 建立 Azure 第 2 代 VM 。
注意
使用快速入門範本時,預設只會啟用 SSH 驗證。 出現提示時,請提供您自己的 SSH 公鑰值,例如 ~/.ssh/id_rsa.pub 的內容。
如果您沒有 SSH 金鑰組,請在 Azure 中建立和使用 Linux VM 的 SSH 金鑰組。
按下 [ 複製 ] 將快速入門範本新增至剪貼簿:
{
"$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 建立快速入門範本 VM
取得或建立快速入門範本之後,請使用 Azure CLI 建立 VM。
下列命令會要求用戶的數個輸入片段。 包括:
- 資源群組名稱(resourceGroupName)
- 裝載 VM 的 Azure 數據中心位置(位置)
- VM 相關資源的名稱(projectName)
- 系統管理員使用者的使用者名稱(使用者名稱)
- 用來存取 VM 終端機的公鑰 (金鑰 )
建立 Azure 虛擬機需要 資源群組。 快速入門範本包括資源群組建立,作為程式的一部分。
若要執行 CLI 腳本,請按兩下 [ 開啟 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
命令中的最後一行會顯示新建立 VM 的公用 IP 位址。 您需要公用IP位址才能連線到虛擬機。
連線至虛擬機器
然後,您可以正常地透過 SSH 連線到您的 VM。 從上述指令提供您自己的公用 IP 位址:
ssh <adminUsername>@<ipAddress>
其他範本
在此範例中,您已建立基本的Linux VM。 如需更多包含應用程式架構或建立更複雜的環境的 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 快速入門範本。
意見反應
https://aka.ms/ContentUserFeedback。
即將登場:在 2024 年,我們將逐步淘汰 GitHub 問題作為內容的意見反應機制,並將它取代為新的意見反應系統。 如需詳細資訊,請參閱:提交並檢視相關的意見反應