Tutorial: Memasang aplikasi dalam set skala komputer virtual dengan Azure PowerShell

Berlaku untuk: ✔️ VM Linux ✔️ Windows VM ✔️ Set skala seragam

Untuk menjalankan aplikasi pada instans komputer virtual (VM) dalam suatu set skala, Anda perlu menginstal komponen aplikasi dan file yang diperlukan terlebih dahulu. Dalam tutorial sebelumnya, Anda mempelajari cara membuat dan menggunakan citra komputer virtual kustom untuk menyebarkan instans komputer virtual Anda. Citra kustom ini mencakup penginstalan dan konfigurasi aplikasi manual. Anda juga dapat mengotomatiskan penginstalan aplikasi ke set skala setelah setiap instans komputer virtual disebarkan, atau memperbarui aplikasi yang sudah berjalan pada set skala. Dalam tutorial ini, Anda akan belajar cara:

  • Menginstal aplikasi secara otomatis ke set skala Anda
  • Menggunakan Ekstensi Skrip Kustom Azure
  • Memperbarui aplikasi yang sedang berjalan pada set skala

Jika Anda tidak memiliki langganan Azure, buat akun gratis sebelum Anda memulai.

Catatan

Artikel ini menggunakan modul Azure Az PowerShell, yang merupakan modul PowerShell yang direkomendasikan untuk berinteraksi dengan Azure. Untuk mulai menggunakan modul Az PowerShell, lihat Menginstal Azure PowerShell. Untuk mempelajari cara bermigrasi ke modul Az PowerShell, lihat Memigrasikan Azure PowerShell dari AzureRM ke Az.

Menggunakan Azure Cloud Shell

Azure meng-hosting Azure Cloud Shell, lingkungan shell interaktif yang dapat Anda gunakan melalui browser. Anda dapat menggunakan Bash atau PowerShell dengan Cloud Shell untuk bekerja dengan layanan Azure. Anda dapat menggunakan perintah Cloud Shell yang telah diinstal sebelumnya untuk menjalankan kode dalam artikel ini tanpa harus menginstal apa pun di lingkungan lokal Anda.

Untuk memulai Azure Cloud Shell:

Opsi Contoh/Tautan
Pilih Coba di sudut kanan atas blok kode. Memilih Coba tidak secara otomatis menyalin kode ke Cloud Shell. Contoh Coba untuk Azure Cloud Shell
Buka https://shell.azure.com, atau pilih tombol Luncurkan Cloud Shell untuk membuka Cloud Shell di browser Anda. Luncurkan Cloud Shell di jendela baru
Pilih tombol Cloud Shell pada bilah menu di kanan atas di portal Microsoft Azure. Tombol Cloud Shell di portal Microsoft Azure

Untuk menjalankan kode dalam artikel ini di Azure Cloud Shell:

  1. Mulai Cloud Shell.

  2. Pilih tombol Salin pada blok kode untuk menyalin kode.

  3. Tempelkan kode ke sesi Cloud Shell dengan memilih Ctrl+Shift+V di Windows dan Linux atau dengan memilih Cmd+Shift+V di macOS.

  4. Pilih Enter untuk menjalankan kode.

Apa itu Azure Custom Script Extension?

Custom Script Extension mengunduh dan mengeksekusi skrip di Azure VM. Ekstensi ini berguna untuk konfigurasi pasca penyebaran, pemasangan perangkat lunak, atau tugas konfigurasi/manajemen lainnya. Skrip dapat diunduh dari penyimpanan Azure atau GitHub, atau disediakan ke portal Microsoft Azure pada run-time ekstensi.

Ekstensi Custom Script terintegrasi dengan templat Azure Resource Manager. Ini juga dapat digunakan dengan Azure CLI, Azure PowerShell, portal Microsoft Azure, atau REST API. Untuk informasi selengkapnya, lihat ringkasan Ekstensi Skrip Kustom.

Untuk melihat Custom Script Extension bekerja, buat set skala yang memasang server web IIS dan menghasilkan nama host set skala instans VM. Definisi Custom Script Extension mengunduh sampel skrip dari GitHub, memasang paket yang diperlukan, lalu menulis nama host instans VM ke halaman HTML dasar.

Membuat set skala

Sekarang, buat set skala komputer virtual dengan New-AzVmss. Untuk mendistribusikan lalu lintas ke instans komputer virtual individual, penyeimbang muatan juga dibuat. Load balancer mencakup aturan untuk mendistribusikan lalu lintas pada port TCP 80. Ini juga memungkinkan lalu lintas desktop jarak jauh pada port TCP 3389 dan PowerShell jarak jauh pada port TCP 5985. Saat diminta, berikan informasi masuk administratif yang Anda inginkan untuk instans komputer virtual di dalam set skala:

New-AzVmss `
  -ResourceGroupName "myResourceGroup" `
  -VMScaleSetName "myScaleSet" `
  -Location "EastUS" `
  -VirtualNetworkName "myVnet" `
  -SubnetName "mySubnet" `
  -PublicIpAddressName "myPublicIPAddress" `
  -LoadBalancerName "myLoadBalancer" `
  -UpgradePolicyMode "Automatic"

Dibutuhkan beberapa menit untuk membuat dan mengonfigurasi semua sumber daya dan VM set skala.

Membuat definisi Custom Script Extension

Azure PowerShell menggunakan hashtable untuk menyimpan file yang akan diunduh dan perintah yang akan dijalankan. Dalam contoh berikut, sampel skrip dari GitHub digunakan. Pertama, buat objek konfigurasi ini sebagai berikut:

$customConfig = @{
  "fileUris" = (,"https://raw.githubusercontent.com/Azure-Samples/compute-automation-configurations/master/automate-iis.ps1");
  "commandToExecute" = "powershell -ExecutionPolicy Unrestricted -File automate-iis.ps1"
}

Sekarang, terapkan Custom Script Extension dengan Add-AzVmssExtension. Objek konfigurasi yang sebelumnya ditentukan diteruskan ke ekstensi. Perbarui dan jalankan ekstensi pada instans VM dengan Update-AzVmss.

# Get information about the scale set
$vmss = Get-AzVmss `
          -ResourceGroupName "myResourceGroup" `
          -VMScaleSetName "myScaleSet"

# Add the Custom Script Extension to install IIS and configure basic website
$vmss = Add-AzVmssExtension `
  -VirtualMachineScaleSet $vmss `
  -Name "customScript" `
  -Publisher "Microsoft.Compute" `
  -Type "CustomScriptExtension" `
  -TypeHandlerVersion 1.9 `
  -Setting $customConfig

# Update the scale set and apply the Custom Script Extension to the VM instances
Update-AzVmss `
  -ResourceGroupName "myResourceGroup" `
  -Name "myScaleSet" `
  -VirtualMachineScaleSet $vmss

Setiap instans VM dalam set skala mengunduh dan menjalankan skrip dari GitHub. Dalam contoh yang lebih kompleks, beberapa komponen dan file aplikasi dapat diinstal. Jika set skala ditingkatkan, instans VM baru secara otomatis menerapkan definisi Custom Script Extension yang sama dan memasang aplikasi yang diperlukan.

Mengizinkan lalu lintas ke aplikasi

Untuk mengizinkan akses ke aplikasi web dasar, buat grup keamanan jaringan dengan New-AzNetworkSecurityRuleConfig dan New-AzNetworkSecurityGroup. Untuk informasi selengkapnya, lihat Jaringan untuk set skala komputer virtual Azure.


#Create a rule to allow traffic over port 80
$nsgFrontendRule = New-AzNetworkSecurityRuleConfig `
  -Name myFrontendNSGRule `
  -Protocol Tcp `
  -Direction Inbound `
  -Priority 200 `
  -SourceAddressPrefix * `
  -SourcePortRange * `
  -DestinationAddressPrefix * `
  -DestinationPortRange 80 `
  -Access Allow

#Create a network security group and associate it with the rule
$nsgFrontend = New-AzNetworkSecurityGroup `
  -ResourceGroupName  "myResourceGroup" `
  -Location EastUS `
  -Name myFrontendNSG `
  -SecurityRules $nsgFrontendRule

$vnet = Get-AzVirtualNetwork `
  -ResourceGroupName  "myResourceGroup" `
  -Name myVnet

$frontendSubnet = $vnet.Subnets[0]

$frontendSubnetConfig = Set-AzVirtualNetworkSubnetConfig `
  -VirtualNetwork $vnet `
  -Name mySubnet `
  -AddressPrefix $frontendSubnet.AddressPrefix `
  -NetworkSecurityGroup $nsgFrontend

Set-AzVirtualNetwork -VirtualNetwork $vnet

Menguji set skala Anda

Untuk melihat server web bekerja, dapatkan alamat IP publik load balancer Anda dengan Get-AzPublicIpAddress. Contoh berikut menampilkan alamat IP yang dibuat di grup sumber daya myResourceGroup:

Get-AzPublicIpAddress -ResourceGroupName "myResourceGroup" | Select IpAddress

Masukkan alamat IP publik penyeimbang muatan ke browser web. Load balancer mendistribusikan lalu lintas ke salah satu instans VM Anda, seperti yang ditunjukkan dalam contoh berikut:

Halaman web dasar di IIS

Biarkan browser web terbuka sehingga Anda dapat melihat versi yang diperbarui di langkah berikutnya.

<a name="update-app-deployment">Memperbarui penyebaran aplikasi

Sepanjang siklus hidup set skala, Anda mungkin perlu menerapkan versi aplikasi yang diperbarui. Dengan Custom Script Extension, Anda dapat mereferensikan skrip penerapan yang diperbarui, lalu menerapkan ulang ekstensi ke set skala Anda. Ketika set skala dibuat di langkah sebelumnya, -UpgradePolicyMode diatur ke Otomatis. Pengaturan ini memungkinkan instans VM dalam set skala untuk memperbarui dan menerapkan versi terbaru aplikasi Anda secara otomatis.

Buat definisi konfigurasi baru bernama customConfigv2. Definisi ini menjalankan versi v2 terbaru dari skrip pemasangan aplikasi:

$customConfigv2 = @{
  &quot;fileUris&quot; = (,&quot;https://raw.githubusercontent.com/Azure-Samples/compute-automation-configurations/master/automate-iis-v2.ps1");
  "commandToExecute" = "powershell -ExecutionPolicy Unrestricted -File automate-iis-v2.ps1"
}

Perbarui konfigurasi Custom Script Extension ke instans VM di set skala Anda. Definisi customConfigv2 digunakan untuk menerapkan versi aplikasi yang diperbarui:

$vmss = Get-AzVmss `
          -ResourceGroupName "myResourceGroup" `
          -VMScaleSetName "myScaleSet"
 
$vmss.VirtualMachineProfile.ExtensionProfile[0].Extensions[0].Settings = $customConfigv2
 
Update-AzVmss `
  -ResourceGroupName "myResourceGroup" `
  -Name "myScaleSet" `
  -VirtualMachineScaleSet $vmss

Semua instans VM dalam set skala secara otomatis diperbarui dengan versi terbaru halaman web sampel. Untuk melihat versi yang diperbarui, refresh situs web di browser Anda:

Halaman web yang diperbarui di IIS

Membersihkan sumber daya

Untuk menghapus set skala dan sumber daya tambahan Anda, hapus grup sumber daya dan semua sumber dayanya dengan Remove-AzResourceGroup. Parameter -Force mengonfirmasi bahwa Anda ingin menghapus sumber daya tanpa permintaan tambahan untuk melakukannya. Parameter -AsJob mengembalikan kontrol ke permintaan tanpa menunggu operasi selesai.

Remove-AzResourceGroup -Name "myResourceGroup" -Force -AsJob

Langkah berikutnya

Dalam tutorial ini, Anda mempelajari cara memasang dan memperbarui aplikasi secara otomatis pada set skala Anda dengan Azure PowerShell:

  • Memasang aplikasi secara otomatis ke set skala Anda
  • Menggunakan Ekstensi Skrip Kustom Azure
  • Memperbarui aplikasi yang sedang berjalan pada set skala

Lanjutkan ke tutorial berikutnya untuk mempelajari cara menskalakan set skala Anda secara otomatis.