Pertanyaan umum tentang VM di Marketplace Azure

Tanya jawab umum ini mencakup masalah umum yang mungkin Anda temui saat membuat penawaran komputer virtual (VM) di Azure Marketplace.

Bagaimana cara mengonfigurasi jaringan privat virtual (VPN) agar berfungsi dengan VM saya?

Apa kebijakan dukungan Microsoft untuk menjalankan perangkat lunak server Microsoft pada VM berbasis Azure?

Di VM, bagaimana cara mengelola ekstensi skrip kustom di tugas startup?

Untuk detail tentang menggunakan Ekstensi Skrip Kustom menggunakan modul Azure PowerShell, templat Azure Resource Manager, dan langkah-langkah pemecahan masalah pada sistem Windows, lihat Ekstensi Skrip Kustom untuk Windows.

Apakah aplikasi atau layanan 32-bit didukung di Azure Marketplace?

Tidak. Sistem operasi yang didukung dan layanan standar untuk Azure VM semuanya 64-bit. Meskipun sebagian besar sistem operasi 64-bit mendukung versi aplikasi 32-bit untuk kompatibilitas mundur, menggunakan aplikasi 32-bit sebagai bagian dari solusi VM Anda tidak didukung dan sangat tidak dianjurkan. Buat ulang aplikasi Anda sebagai proyek 64-bit.

Untuk informasi selengkapnya, lihat artikel berikut ini:

Kesalahan: VHD sudah terdaftar dengan repositori gambar sebagai sumber daya

Setiap kali saya mencoba membuat gambar dari VHD saya, saya mendapatkan kesalahan "VHD telah terdaftar dengan repositori gambar sebagai sumber daya" di Azure PowerShell. Saya tidak membuat gambar apa pun sebelumnya dan saya juga tidak menemukan gambar dengan nama ini di Azure. Bagaimana cara mengatasi masalah ini?

Masalah ini biasanya muncul jika Anda membuat VM dari VHD yang memiliki kunci. Konfirmasikan bahwa tidak ada VM yang dialokasikan dari VHD ini lalu coba lagi operasinya. Jika masalah ini berlanjut, buka tiket dukungan. Lihat Dukungan untuk Pusat Mitra.

Bagaimana cara membuat VM dari vhd umum?

Menyiapkan templat Azure Resource Manager

Bagian ini menjelaskan cara membuat dan menyebarkan gambar komputer virtual (VM) yang disediakan pengguna dengan menyediakan sistem operasi dan gambar VHD disk data dari hard disk virtual yang disebarkan Azure. Langkah-langkah ini menyebarkan VM menggunakan VHD umum.

  1. Masuk ke portal Azure.

  2. Unggah VHD sistem operasi umum dan disk data VHD ke akun Azure Storage Anda.

  3. Pada beranda, pilih Buat sumber daya, cariPenyebaran Templat, dan pilih Buat.

  4. Pilih Bangun templat Anda sendiri di editor.

    Menunjukkan pilihan templat

  5. Tempelkan templat JSON berikut ke editor dan pilih Simpan.

     {
          "$schema": "https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#",
          "contentVersion": "1.0.0.0",
          "parameters": {
              "userStorageAccountName": {
                  "type": "String"
              },
              "userStorageContainerName": {
                  "defaultValue": "vhds",
                  "type": "String"
              },
              "dnsNameForPublicIP": {
                  "type": "String"
              },
              "adminUserName": {
                  "defaultValue": "isv",
                  "type": "String"
              },
              "adminPassword": {
                  "defaultValue": "",
                  "type": "SecureString"
              },
              "osType": {
                  "defaultValue": "windows",
                  "allowedValues": [
                      "windows",
                      "linux"
                  ],
                  "type": "String"
              },
              "subscriptionId": {
                  "type": "String"
              },
              "location": {
                  "type": "String"
              },
              "vmSize": {
                  "type": "String"
              },
              "publicIPAddressName": {
                  "type": "String"
              },
              "vmName": {
                  "type": "String"
              },
              "virtualNetworkName": {
                  "type": "String"
              },
              "nicName": {
                  "type": "String"
              },
              "vhdUrl": {
                  "type": "String",
                  "metadata": {
                      "description": "VHD Url..."
                  }
              }
          },
          "variables": {
              "addressPrefix": "10.0.0.0/16",
              "subnet1Name": "Subnet-1",
              "subnet2Name": "Subnet-2",
              "subnet1Prefix": "10.0.0.0/24",
              "subnet2Prefix": "10.0.1.0/24",
              "publicIPAddressType": "Dynamic",
              "vnetID": "[resourceId('Microsoft.Network/virtualNetworks',parameters('virtualNetworkName'))]",
              "subnet1Ref": "[concat(variables('vnetID'),'/subnets/',variables('subnet1Name'))]",
              "hostDNSNameScriptArgument": "[concat(parameters('dnsNameForPublicIP'),'.',parameters('location'),'.cloudapp.azure.com')]",
              "osDiskVhdName": "[concat('http://',parameters('userStorageAccountName'),'.blob.core.windows.net/',parameters('userStorageContainerName'),'/',parameters('vmName'),'osDisk.vhd')]"
          },
          "resources": [
              {
                  "type": "Microsoft.Network/publicIPAddresses",
                  "apiVersion": "2015-06-15",
                  "name": "[parameters('publicIPAddressName')]",
                  "location": "[parameters('location')]",
                  "properties": {
                      "publicIPAllocationMethod": "[variables('publicIPAddressType')]",
                      "dnsSettings": {
                          "domainNameLabel": "[parameters('dnsNameForPublicIP')]"
                      }
                  }
              },
              {
                  "type": "Microsoft.Network/virtualNetworks",
                  "apiVersion": "2015-06-15",
                  "name": "[parameters('virtualNetworkName')]",
                  "location": "[parameters('location')]",
                  "properties": {
                      "addressSpace": {
                          "addressPrefixes": [
                              "[variables('addressPrefix')]"
                          ]
                      },
                      "subnets": [
                          {
                              "name": "[variables('subnet1Name')]",
                              "properties": {
                                  "addressPrefix": "[variables('subnet1Prefix')]"
                              }
                          },
                          {
                              "name": "[variables('subnet2Name')]",
                              "properties": {
                                  "addressPrefix": "[variables('subnet2Prefix')]"
                              }
                          }
                      ]
                  }
              },
              {
                  "type": "Microsoft.Network/networkInterfaces",
                  "apiVersion": "2015-06-15",
                  "name": "[parameters('nicName')]",
                  "location": "[parameters('location')]",
                  "dependsOn": [
                      "[concat('Microsoft.Network/publicIPAddresses/', parameters('publicIPAddressName'))]",
                      "[concat('Microsoft.Network/virtualNetworks/', parameters('virtualNetworkName'))]"
                  ],
                  "properties": {
                      "ipConfigurations": [
                          {
                              "name": "ipconfig1",
                              "properties": {
                                  "privateIPAllocationMethod": "Dynamic",
                                  "publicIPAddress": {
                                      "id": "[resourceId('Microsoft.Network/publicIPAddresses',parameters('publicIPAddressName'))]"
                                  },
                                  "subnet": {
                                      "id": "[variables('subnet1Ref')]"
                                  }
                              }
                          }
                      ]
                  }
              },
              {
                  "type": "Microsoft.Compute/virtualMachines",
                  "apiVersion": "2015-06-15",
                  "name": "[parameters('vmName')]",
                  "location": "[parameters('location')]",
                  "dependsOn": [
                      "[concat('Microsoft.Network/networkInterfaces/', parameters('nicName'))]"
                  ],
                  "properties": {
                      "hardwareProfile": {
                          "vmSize": "[parameters('vmSize')]"
                      },
                      "osProfile": {
                          "computername": "[parameters('vmName')]",
                          "adminUsername": "[parameters('adminUsername')]",
                          "adminPassword": "[parameters('adminPassword')]"
                      },
                      "storageProfile": {
                          "osDisk": {
                              "name": "[concat(parameters('vmName'),'-osDisk')]",
                              "osType": "[parameters('osType')]",
                              "caching": "ReadWrite",
                              "image": {
                                  "uri": "[parameters('vhdUrl')]"
                              },
                              "vhd": {
                                  "uri": "[variables('osDiskVhdName')]"
                              },
                              "createOption": "FromImage"
                          }
                      },
                      "networkProfile": {
                          "networkInterfaces": [
                              {
                                  "id": "[resourceId('Microsoft.Network/networkInterfaces',parameters('nicName'))]"
                              }
                          ]
                      }
                  }
              }
          ]
      }
    
  6. Berikan nilai parameter untuk halaman properti penyebaran kustom yang ditampilkan.

    ResourceGroupName Nama grup sumber daya Azure yang sudah ada. Biasanya, gunakan RG yang sama dengan brankas kunci Anda.
    TemplateFile Nama jalur penuh ke berkas VHDtoImage.json.
    userStorageAccountName Nama akun penyimpanan.
    dnsNameForPublicIP Nama DNS untuk IP publik; harus huruf kecil.
    subscriptionId Pengidentifikasi langganan Azure.
    Lokasi Lokasi geografis Azure standar dari grup sumber daya.
    vmName Nama komputer virtual.
    vhdUrl Alamat web hard disk virtual.
    vmSize Ukuran instans komputer virtual.
    publicIPAddressName Nama alamat IP publik.
    virtualNetworkName Nama jaringan virtual.
    nicName Nama kartu antarmuka jaringan untuk jaringan virtual.
    adminUserName Nama pengguna akun administrator.
    adminPassword Kata sandi administrator.
  7. Setelah Anda menyediakan nilai-nilai ini, pilih Beli.

    Azure memulai penyebaran. Azure membuat VM baru dengan VHD yang ditentukan dan tidak terkelola di jalur akun penyimpanan yang ditentukan. Anda dapat melacak kemajuan di portal Microsoft Azure dengan memilih Komputer Virtual di sisi kiri portal. Saat VM dibuat, status berubah dari Mulai ke Berjalan.

    Untuk penyebaran VM generasi 2, gunakan templat ini:

    {
         "$schema": "https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#",
         "contentVersion": "1.0.0.0",
         "parameters": {
             "userStorageAccountName": {
                 "type": "String"
             },
             "userStorageContainerName": {
                 "defaultValue": "vhds",
                 "type": "String"
             },
             "dnsNameForPublicIP": {
                 "type": "String"
             },
             "adminUserName": {
                 "defaultValue": "isv",
                 "type": "String"
             },
             "adminPassword": {
                 "defaultValue": "",
                 "type": "SecureString"
             },
             "osType": {
                 "defaultValue": "windows",
                 "allowedValues": [
                     "windows",
                     "linux"
                 ],
                 "type": "String"
             },
             "subscriptionId": {
                 "type": "String"
             },
             "location": {
                 "type": "String"
             },
             "vmSize": {
                 "type": "String"
             },
             "publicIPAddressName": {
                 "type": "String"
             },
             "vmName": {
                 "type": "String"
             },
             "virtualNetworkName": {
                 "type": "String"
             },
             "nicName": {
                 "type": "String"
             },
             "vhdUrl": {
                 "type": "String",
                 "metadata": {
                     "description": "VHD Url..."
                 }
             }
         },
         "variables": {
             "addressPrefix": "10.0.0.0/16",
             "subnet1Name": "Subnet-1",
             "subnet2Name": "Subnet-2",
             "subnet1Prefix": "10.0.0.0/24",
             "subnet2Prefix": "10.0.1.0/24",
             "publicIPAddressType": "Dynamic",
             "vnetID": "[resourceId('Microsoft.Network/virtualNetworks',parameters('virtualNetworkName'))]",
             "subnet1Ref": "[concat(variables('vnetID'),'/subnets/',variables('subnet1Name'))]",
             "hostDNSNameScriptArgument": "[concat(parameters('dnsNameForPublicIP'),'.',parameters('location'),'.cloudapp.azure.com')]",
             "osDiskVhdName": "[concat('http://',parameters('userStorageAccountName'),'.blob.core.windows.net/',parameters('userStorageContainerName'),'/',parameters('vmName'),'osDisk.vhd')]"
         },
         "resources": [
             {
                 "type": "Microsoft.Network/publicIPAddresses",
                 "apiVersion": "2015-06-15",
                 "name": "[parameters('publicIPAddressName')]",
                 "location": "[parameters('location')]",
                 "properties": {
                     "publicIPAllocationMethod": "[variables('publicIPAddressType')]",
                     "dnsSettings": {
                         "domainNameLabel": "[parameters('dnsNameForPublicIP')]"
                     }
                 }
             },
             {
                 "type": "Microsoft.Network/virtualNetworks",
                 "apiVersion": "2015-06-15",
                 "name": "[parameters('virtualNetworkName')]",
                 "location": "[parameters('location')]",
                 "properties": {
                     "addressSpace": {
                         "addressPrefixes": [
                             "[variables('addressPrefix')]"
                         ]
                     },
                     "subnets": [
                         {
                             "name": "[variables('subnet1Name')]",
                             "properties": {
                                 "addressPrefix": "[variables('subnet1Prefix')]"
                             }
                         },
                         {
                             "name": "[variables('subnet2Name')]",
                             "properties": {
                                 "addressPrefix": "[variables('subnet2Prefix')]"
                             }
                         }
                     ]
                 }
             },
             {
                 "type": "Microsoft.Network/networkInterfaces",
                 "apiVersion": "2015-06-15",
                 "name": "[parameters('nicName')]",
                 "location": "[parameters('location')]",
                 "dependsOn": [
                     "[concat('Microsoft.Network/publicIPAddresses/', parameters('publicIPAddressName'))]",
                     "[concat('Microsoft.Network/virtualNetworks/', parameters('virtualNetworkName'))]"
                 ],
                 "properties": {
                     "ipConfigurations": [
                         {
                             "name": "ipconfig1",
                             "properties": {
                                 "privateIPAllocationMethod": "Dynamic",
                                 "publicIPAddress": {
                                     "id": "[resourceId('Microsoft.Network/publicIPAddresses',parameters('publicIPAddressName'))]"
                                 },
                                 "subnet": {
                                     "id": "[variables('subnet1Ref')]"
                                 }
                             }
                         }
                     ]
                 }
             },
             {
                 "type": "Microsoft.Compute/virtualMachines",
                 "apiVersion": "2015-06-15",
                 "name": "[parameters('vmName')]",
                 "location": "[parameters('location')]",
                 "dependsOn": [
                     "[concat('Microsoft.Network/networkInterfaces/', parameters('nicName'))]"
                 ],
                 "properties": {
                     "hardwareProfile": {
                         "vmSize": "[parameters('vmSize')]"
                     },
                     "osProfile": {
                         "computername": "[parameters('vmName')]",
                         "adminUsername": "[parameters('adminUsername')]",
                         "adminPassword": "[parameters('adminPassword')]"
                     },
                     "storageProfile": {
                         "osDisk": {
                             "name": "[concat(parameters('vmName'),'-osDisk')]",
                             "osType": "[parameters('osType')]",
                             "caching": "ReadWrite",
                             "image": {
                                 "uri": "[parameters('vhdUrl')]"
                             },
                             "vhd": {
                                 "uri": "[variables('osDiskVhdName')]"
                             },
                             "createOption": "FromImage"
                         }
                     },
                     "networkProfile": {
                         "networkInterfaces": [
                             {
                                 "id": "[resourceId('Microsoft.Network/networkInterfaces',parameters('nicName'))]"
                             }
                         ]
                     }
                 }
             }
         ]
     }
    

Menyebarkan Azure VM menggunakan PowerShell

Salin dan edit skrip berikut untuk menyediakan nilai untuk variabel $storageaccount dan $vhdUrl. Jalankan untuk membuat sumber daya Azure VM dari VHD umum yang telah ada.

# storage account of existing generalized VHD
$storageaccount = "testwinrm11815"
# generalized VHD URL
$vhdUrl = "https://testwinrm11815.blob.core.windows.net/vhds/testvm1234562016651857.vhd"

echo "New-AzResourceGroupDeployment -Name "dplisvvm$postfix" -ResourceGroupName "$rgName" -TemplateFile "C:\certLocation\VHDtoImage.json" -userStorageAccountName "$storageaccount" -dnsNameForPublicIP "$vmName" -subscriptionId "$mysubid" -location "$location" -vmName "$vmName" -vaultName "$kvname" -vaultResourceGroup "$rgName" -certificateUrl
$objAzureKeyVaultSecret.Id -vhdUrl "$vhdUrl" -vmSize "Standard\_A2" -publicIPAddressName "myPublicIP1" -virtualNetworkName "myVNET1" -nicName "myNIC1" -adminUserName "isv" -adminPassword $pwd"

# deploying VM with existing VHD
New-AzResourceGroupDeployment -Name "dplisvvm$postfix" -ResourceGroupName "$rgName"

Bagaimana cara menguji gambar pratinjau tersembunyi?

Anda dapat menyebarkan gambar pratinjau tersembunyi menggunakan templat mulai cepat. Untuk menyebarkan gambar pratinjau,

  1. Buka templat mulai cepat masing-masing untuk Linux atau Windows, pilih "Sebarkan ke Azure". Prosedur ini akan membawa Anda ke portal Azure.
  2. Di portal Microsoft Azure, pilih "Edit templat".
  3. Dalam templat JSON, cari imageReference dan perbarui publisherid, offerid, skuid, dan versi gambar. Untuk menguji gambar pratinjau, tambahkan "-PREVIEW" ke offerid.
  4. Pilih Simpan.
  5. Isi sisa detailnya. Meninjau dan Membuat