Menyebarkan aplikasi web Node.js di Azure

Dalam mulai cepat ini, Anda akan mempelajari cara membuat dan menyebarkan aplikasi web Node.js (Ekspres) pertama Anda ke Azure App Service. App Service mendukung berbagai versi Node.js di Linux dan Windows.

Mulai cepat ini mengonfigurasi aplikasi App Service di tingkat Gratis dan tidak dikenakan biaya untuk langganan Azure Anda.

Video ini menunjukkan kepada Anda cara menyebarkan aplikasi web Node.js di Azure.

Langkah-langkah dalam video juga dijelaskan di bagian berikut.

Menyiapkan lingkungan awal Anda

  • Memiliki akun Azure dengan langganan aktif. Buat akun secara gratis.
  • Instal Node.js LTS dan npm. Jalankan perintah node --version untuk memverifikasi bahwa Node.js dipasang.
  • Instal Azure CLI, tempat Anda menjalankan perintah di shell apa pun untuk membuat dan mengonfigurasi sumber daya Azure.

Membuat aplikasi Node.js Anda

Pada langkah ini, Anda membuat aplikasi Node.js dasar dan memastikannya berjalan di komputer Anda.

Tip

Jika Anda telah menyelesaikan tutorial Node.js, Anda dapat melompati ke Sebarkan ke Azure.

  1. Buat aplikasi Node.js menggunakan Generator Ekspres, yang diinstal secara default dengan Node.js dan NPM.

    npx express-generator myExpressApp --view ejs
    
  2. Ubah ke direktori aplikasi dan pasang paket NPM.

    cd myExpressApp && npm install
    
  3. Mulai server pengembangan dengan informasi debug.

    DEBUG=myexpressapp:* npm start
    
  4. Di browser, navigasikan ke http://localhost:3000. Anda seharusnya melihat sesuatu seperti berikut:

    Running Express Application

Sebarkan ke Azure

Sebelum melanjutkan, pastikan Anda telah memasang dan mengonfigurasi semua prasyarat.

Catatan

Agar aplikasi Node.js Anda berjalan di Azure, aplikasi perlu mendengarkan port yang disediakan oleh variabel lingkungan PORT. Di aplikasi Ekspres yang Anda hasilkan, variabel lingkungan ini sudah digunakan dalam skrip mulai bin/www (cari process.env.PORT).

Masuk ke Azure

  1. Di terminal, pastikan Anda berada di direktori myExpressApp, lalu mulai Visual Studio Code dengan perintah berikut:

    code .
    
  2. Di Visual Studio Code, di Bilah Aktivitas, pilih ikon logo Azure.

  3. Di penjelajah App Service, pilih Masuk ke Azure... dan ikuti petunjuknya.

    Di Visual Studio Code, Anda akan melihat alamat email Azure di Bilah Status dan langganan Anda di penjelajah AZURE APP SERVICE.

    sign in to Azure

Mengonfigurasi aplikasi App Service dan menyebarkan kode

  1. Pilih folder myExpressApp.
  1. Klik kanan pada App Services dan pilih Buat Aplikasi Web baru. Sebuah kontainer Linux digunakan secara default.

  2. Ketik nama unik global untuk aplikasi web Anda dan tekan Enter. Nama harus unik di semua Azure dan hanya menggunakan karakter alfanumerik ('A-Z', 'a-z', dan '0-9') dan tanda hubung ('-').

  3. Di Pilih tumpukan runtime, pilih versi Node.js yang Anda inginkan. Disarankan versi LTS.

  4. Di Pilih tingkat harga, pilih Gratis (F1) dan tunggu hingga sumber daya dibuat di Azure.

  5. Di popup Selalu sebarkan ruang kerja "myExpressApp" ke <app-name>", pilih Ya. Dengan cara ini, selama Anda berada di ruang kerja yang sama, Visual Studio Code menyebarkan ke aplikasi App Service yang sama setiap kali.

    Saat Visual Studio Code membuat sumber daya Azure dan menyebarkan kode, visual Studio Code menampilkan pemberitahuan kemajuan.

  6. Setelah penyebaran selesai, pilih Telusuri Situs Web di popup pemberitahuan. Browser harus menampilkan halaman default Ekspres.

Di terminal, pastikan Anda berada di direktori myExpressApp, dan sebarkan kode di folder lokal Anda (myExpressApp) menggunakan perintah az webapp up:

az webapp up --sku F1 --name <app-name>
  • Jika perintah az tidak dikenali, pastikan Anda telah menginstal Azure CLI seperti yang dijelaskan dalam Menyiapkan lingkungan awal Anda.
  • Ganti <app_name> dengan nama yang unik di seluruh Azure (karakter yang valid adalah a-z, 0-9, dan -). Pola yang baik adalah menggunakan kombinasi nama perusahaan dan pengidentifikasi aplikasi Anda.
  • Argumen --sku F1 membuat aplikasi web pada tingkat harga Gratis, yang tidak dikenakan biaya.
  • Anda dapat secara opsional menyertakan argumen --location <location-name> di mana <location_name> adalah wilayah Azure yang tersedia. Anda dapat mengambil daftar wilayah yang diizinkan untuk akun Azure Anda dengan menjalankan perintah az account list-locations.
  • Perintah ini membuat aplikasi Linux untuk Node.js secara default. Untuk membuat aplikasi Windows sebagai gantinya, gunakan argumen --os-type.
  • Jika Anda melihat kesalahan, "Tidak dapat mendeteksi secara otomatis tumpukan runtime aplikasi Anda," pastikan Anda menjalankan perintah di direktori myExpressApp (Lihat Memecahkan masalah deteksi otomatis dengan az webapp up).

Perintah ini mungkin perlu waktu beberapa menit untuk diselesaikan. Saat berjalan, perintah ini memberikan pesan tentang membuat grup sumber daya, paket App Service dan aplikasi hosting, mengonfigurasi pengelogan, lalu melakukan penyebaran ZIP. Kemudian perintah memberikan pesan, "Anda dapat meluncurkan aplikasi di http:// <nama aplikasi>.azurewebsites.net", yang merupakan URL aplikasi di Azure.

The webapp '<app-name>' doesn't exist
Creating Resource group '<group-name>' ...
Resource group creation complete
Creating AppServicePlan '<app-service-plan-name>' ...
Creating webapp '<app-name>' ...
Configuring default logging for the app, if not already enabled
Creating zip with contents of dir /home/cephas/myExpressApp ...
Getting scm site credentials for zip deployment
Starting zip deployment. This operation can take a while to complete ...
Deployment endpoint responded with status code 202
You can launch the app at http://<app-name>.azurewebsites.net
{
  "URL": "http://<app-name>.azurewebsites.net",
  "appserviceplan": "<app-service-plan-name>",
  "location": "centralus",
  "name": "<app-name>",
  "os": "<os-type>",
  "resourcegroup": "<group-name>",
  "runtime_version": "node|10.14",
  "runtime_version_detected": "0.0",
  "sku": "FREE",
  "src_path": "//home//cephas//myExpressApp"
}

Catatan

Perintah az webapp up melakukan tindakan berikut:

Masuk ke portal Azure

Masuk ke portal Azure.

Membuat sumber daya Azure

  1. Untuk mulai membuat aplikasi Node.js, telusuri ke https://portal.azure.com/#create/Microsoft.WebSite.

  2. Di tab Dasar-dasar, di bawah Detail proyek, pastikan langganan yang benar dipilih, lalu pilih grup sumber daya Buat baru. Ketik myResourceGroup untuk namanya.

    Screenshot of the Project details section showing where you select the Azure subscription and the resource group for the web app

  3. Di bagian Detail Instans, ketik nama unik global untuk aplikasi web Anda dan pilih Kode. Pilih Tumpukan Runtime Node 18 LTS, Sistem Operasi, dan Wilayah tempat Anda ingin melayani aplikasi.

    Screenshot of the Instance details section where you provide a name for the virtual machine and select its region, image and size

  4. Di bawah Paket Azure App Service, pilih Buat baru Paket Azure App Service. Ketik myAppServicePlan untuk nama. Untuk mengubah ke tingkat Gratis, pilih Ubah ukuran, pilih tab Pengembangan/Pengujian, pilih F1, dan pilih tombol Terapkan di bagian bawah halaman.

    Screenshot of the Administrator account section where you provide the administrator username and password

  5. Pilih tombol Tinjau + buat di bagian bawah halaman.

    Screenshot showing the Review and create button at the bottom of the page

  6. Setelah validasi berjalan, pilih tombol Create di bagian bawah halaman.

  7. Setelah penyebaran selesai, pilih Buka sumber daya.

    Screenshot showing the next step of going to the resource

Mendapatkan kredensial FTPS

Azure App Service mendukung dua jenis kredensial untuk penerapan FTP/S. Kredensial ini tidak sama dengan kredensial langganan Azure Anda. Di bagian ini, Anda mendapatkan kredensial cakupan aplikasi untuk digunakan dengan FileZilla.

  1. Dari halaman aplikasi Azure App Service, pilih Pusat Penyebaran di menu sebelah kiri dan pilih tab Kredensial FTPS.

    FTPS deployment credentials

  2. Buka FileZilla dan buat situs baru.

  3. Dari tab kredensial FTPS, di bawah Cakupan aplikasi, salin titik akhir FTPS, Nama Pengguna FTPS, dan Kata Sandi ke fileZilla.

    FTPS connection details

  4. Pilih Hubungkan di FileZilla.

Menyebarkan file dengan FTPS

  1. Salin semua file dan file direktori ke direktori /site/wwwroot di Azure.

    FileZilla deploy files

  2. Telusuri URL aplikasi Anda untuk memverifikasi bahwa aplikasi berjalan dengan benar.

Menyebarkan ulang pembaruan

Anda dapat menerapkan perubahan pada aplikasi ini dengan melakukan pengeditan di Visual Studio Code, menyimpan file, lalu menyebarkan ulang ke aplikasi Azure Anda. Misalnya:

  1. Dari proyek contoh, buka views/index.ejs dan ubah

    <p>Welcome to <%= title %></p>
    

    ke

    <p>Welcome to Azure</p>
    
  1. Di penjelajah App Service, pilih ikon Sebarkan ke Aplikasi Web lagi, konfirmasikan dengan mengklik Sebarkan lagi.

  2. Tunggu hingga penyebaran selesai, kemudian pilih Telusuri Situs Web di popup pemberitahuan. Anda akan melihat bahwa pesan Welcome to Express telah diubah menjadi Welcome to Azure!.

  1. Simpan perubahan Anda, lalu sebarkan ulang aplikasi menggunakan perintah az webapp up lagi tanpa argumen untuk Linux. Tambahkan --os-type Windows untuk Windows:

    az webapp up
    

    Perintah ini menggunakan nilai yang cache-nya disimpan secara lokal dalam file .azure/config, termasuk nama aplikasi, grup sumber daya, dan paket App Service.

  2. Setelah penyebaran selesai, refresh halaman web http://<app-name>.azurewebsites.net. Anda akan melihat bahwa pesan Welcome to Express telah diubah menjadi Welcome to Azure!.

  1. Simpan perubahan Anda, lalu sebarkan ulang aplikasi menggunakan klien FTP Anda.

  2. Setelah penyebaran selesai, refresh halaman web http://<app-name>.azurewebsites.net. Anda akan melihat bahwa pesan Welcome to Express telah diubah menjadi Welcome to Azure!.

Log Streaming

Anda dapat menampilkan output log (panggilan ke console.log()) dari aplikasi Azure langsung di jendela output Visual Studio Code.

  1. Di penjelajah Azure App Service, klik kanan node aplikasi dan pilih Mulai Log Streaming.

    Start Streaming Logs

  2. Jika diminta untuk menghidupkan ulang aplikasi, pilih Ya. Setelah aplikasi dihidupkan ulang, jendela output Visual Studio Code terbuka dengan koneksi ke aliran log.

  3. Setelah beberapa detik, jendela output menunjukkan pesan yang menunjukkan bahwa Anda tersambung ke layanan streaming log. Anda dapat menghasilkan lebih banyak aktivitas output dengan me-refresh halaman di browser.

     Connecting to log stream...
     2020-03-04T19:29:44  Welcome, you are now connected to log-streaming service. The default timeout is 2 hours.
     Change the timeout with the App Setting SCM_LOGSTREAM_TIMEOUT (in seconds).
     

Anda dapat mengakses log konsol yang dihasilkan dari dalam aplikasi dan kontainer tempat konsol dijalankan. Log termasuk output yang dihasilkan oleh panggilan ke console.log().

Untuk mengalirkan log, jalankan perintah az webapp log tail:

az webapp log tail

Perintah ini menggunakan nama grup sumber daya yang ditembolokan dalam file .azure/config.

Anda juga dapat menyertakan parameter --logs dengan perintah az webapp up untuk membuka aliran log secara otomatis saat penyebaran.

Refresh aplikasi di browser untuk menghasilkan log konsol, yang mencakup pesan yang menjelaskan permintaan HTTP ke aplikasi. Jika tidak ada output yang muncul segera, coba lagi dalam 30 detik.

Untuk menghentikan pengaliran log kapan saja, tekan Ctrl+C di terminal.

Anda dapat mengakses log konsol yang dihasilkan dari dalam aplikasi dan kontainer tempat konsol dijalankan. Anda dapat melakukan streaming output log (panggilan ke console.log()) dari aplikasi Node.js langsung di portal Microsoft Azure.

  1. Di halaman Azure App Service yang sama untuk aplikasi Anda, gunakan menu sebelah kiri untuk menggulir ke bagian Pemantauan dan pilih Aliran log.

    Screenshot of Log stream in Azure App service.

  2. Setelah beberapa detik, jendela output menunjukkan pesan yang menunjukkan bahwa Anda tersambung ke layanan streaming log. Anda dapat menghasilkan lebih banyak aktivitas output dengan me-refresh halaman di browser.

     Connecting...
     2021-10-26T21:04:14  Welcome, you are now connected to log-streaming service.
     Starting Log Tail -n 10 of existing logs ----
     /appsvctmp/volatile/logs/runtime/81b1b83b27ea1c3d598a1cdec28c71c4074ce66c735d0be57f15a8d07cb3178e.log
     2021-10-26T21:04:08.614384810Z: [INFO]
     2021-10-26T21:04:08.614393710Z: [INFO]  # Enter the source directory to make sure the script runs where the user expects
     2021-10-26T21:04:08.614399010Z: [INFO]  cd "/home/site/wwwroot"
     2021-10-26T21:04:08.614403210Z: [INFO]
     2021-10-26T21:04:08.614407110Z: [INFO]  export NODE_PATH=/usr/local/lib/node_modules:$NODE_PATH
     2021-10-26T21:04:08.614411210Z: [INFO]  if [ -z "$PORT" ]; then
     2021-10-26T21:04:08.614415310Z: [INFO]          export PORT=8080
     2021-10-26T21:04:08.614419610Z: [INFO]  fi
     2021-10-26T21:04:08.614423411Z: [INFO]
     2021-10-26T21:04:08.614427211Z: [INFO]  node /opt/startup/default-static-site.js
     Ending Log Tail of existing logs ---
     

Membersihkan sumber daya

Di langkah-langkah sebelumnya, Anda membuat sumber daya Azure dalam grup sumber daya. Langkah-langkah membuat dalam mulai cepat ini menempatkan semua sumber daya dalam grup sumber daya ini. Untuk membersihkannya, Anda hanya perlu menghapus grup sumber daya.

  1. Dalam ekstensi Azure Visual Studio, perluas penjelajah Grup Sumber Daya.

  2. Perluas langganan, klik kanan grup sumber daya yang Anda buat sebelumnya, dan pilih Hapus.

    Screenshot of the Visual Studio Code navigation to delete a resource that contains App Service resources.

  3. Saat diminta, konfirmasi penghapusan Anda dengan memasukkan nama grup sumber daya yang Anda hapus. Setelah Anda mengonfirmasi, grup sumber daya dihapus, dan Anda melihat pemberitahuan saat selesai.

Di langkah-langkah sebelumnya, Anda membuat sumber daya Azure dalam grup sumber daya. Grup sumber daya memiliki nama seperti "appsvc_rg_Linux_CentralUS" tergantung lokasi Anda.

Jika Anda tidak membutuhkan sumber daya ini di masa mendatang, hapus grup sumber daya dengan menjalankan perintah berikut:

az group delete --no-wait

Perintah ini menggunakan nama grup sumber daya yang ditembolokan dalam file .azure/config.

Argumen --no-wait memungkinkan perintah untuk kembali sebelum operasi selesai.

Saat tidak lagi diperlukan, Anda dapat menghapus grup sumber daya, Layanan aplikasi, dan semua sumber daya terkait.

  1. Dari halaman gambaran umum Azure App Service, pilih grup sumber daya yang Anda buat di langkah Buat sumber daya Azure.

    Resource group in App Service overview page

  2. Dari halaman grup sumber daya, pilih Hapus grup sumber daya. Konfirmasi nama grup sumber daya untuk menyelesaikan penghapusan sumber daya.

    Delete resource group

Langkah berikutnya

Selamat, Anda telah berhasil menyelesaikan panduan mulai cepat ini!

Lihat ekstensi Azure lainnya.

Atau dapatkan semuanya dengan memasang paket ekstensi Paket Simpul untuk Azure.