Not
Bu sayfaya erişim yetkilendirme gerektiriyor. Oturum açmayı veya dizinleri değiştirmeyi deneyebilirsiniz.
Bu sayfaya erişim yetkilendirme gerektiriyor. Dizinleri değiştirmeyi deneyebilirsiniz.
Bu hızlı başlangıçta ilk Node.js (Express) web uygulamanızı oluşturmayı ve Azure App Service'e dağıtmayı öğreneceksiniz. App Service, hem Linux hem de Windows üzerinde çeşitli Node.js sürümlerini destekler.
Bu hızlı başlangıç, Ücretsiz katmanda bir Uygulama Hizmeti uygulaması yapılandırır ve Azure aboneliğiniz için herhangi bir maliyete neden olmaz.
Bu video, Azure'da bir Node.js web uygulamasının nasıl dağıtılacağını gösteriyor.
Videodaki adımlar, aşağıdaki bölümlerde de açıklanmaktadır.
Başlangıç ortamınızı ayarlayın
- Azure hesabınızda aktif bir abonelik bulundurun. Hesabınız yoksa ücretsiz bir hesap oluşturabilirsiniz.
-
Node.js LTS'yi yükleyin. Komut
node --version'u çalıştırarak Node.js'in yüklü olup olmadığını doğrulayın. - Visual Studio Code’u yükleyin.
- Visual Studio Code için Azure App Service uzantısını kurun.
- Azure hesabınızda aktif bir abonelik bulundurun. Hesabınız yoksa ücretsiz bir hesap oluşturabilirsiniz.
-
Node.js LTS'yi yükleyin. Komut
node --version'u çalıştırarak Node.js'in yüklü olup olmadığını doğrulayın. - Azure kaynaklarını oluşturmak ve yapılandırmak için bir kabukta komut çalıştırmak için kullanabileceğiniz Azure CLI'yi yükleyin.
- Azure hesabınızda aktif bir abonelik bulundurun. Hesabınız yoksa ücretsiz bir hesap oluşturabilirsiniz.
-
Node.js LTS'yi yükleyin. Komut
node --version'u çalıştırarak Node.js'in yüklü olup olmadığını doğrulayın. - Dosyaları App Service'e aktarmak için FileZilla gibi bir FTP istemcisine sahip olun.
Node.js uygulamanızı oluşturma
Bu adımda, temel bir Node.js uygulaması oluşturur ve bilgisayarınızda çalıştığından emin olursunuz.
Tavsiye
Node.js öğreticisini tamamladıysanız Azure'a dağıtma bölümüne atlayabilirsiniz.
Node.js ve npm ile varsayılan olarak yüklenen express uygulama oluşturucusunu kullanarak Node.js bir uygulama oluşturun.
npx express-generator myExpressApp --view ejsOluşturucuyu ilk kez yüklüyorsanız npx yüklemeyi kabul etmenizi ister.
Uygulamanın dizinine geçin ve npm paketlerini yükleyin.
cd myExpressApp && npm installBağımlılıkları en güvenli sürüme güncelleştirin.
npm audit fix --forceGeliştirme sunucusunu hata ayıklama bilgileriyle başlatın.
DEBUG=myexpressapp:* npm startBir tarayıcıda
http://localhost:3000adresine gidin. Şuna benzer bir şey görmelisiniz:
Azure'a Dağıt
Devam etmeden önce, tüm ön koşulların yüklendiğinden ve yapılandırıldığından emin olun.
Uyarı
Node.js uygulamanızın Azure’da çalışması için, PORT ortam değişkeni tarafından sağlanan portta dinlemesi gerekmektedir. Oluşturduğunuz Express uygulamasında, bu ortam değişkeni başlangıç betiği kutusunda/www dosyasında zaten kullanılıyor. (Ara process.env.PORT.)
Azure'a Giriş Yap
Terminalde myExpressApp dizininde olduğunuzdan emin olun ve ardından Visual Studio Code'u aşağıdaki komutla başlatın:
code .Visual Studio Code'daki Etkinlik Çubuğu'nda Azure logosunu seçin.
Azure hesabınızla oturum açtığınızdan emin olun.
Uygulama Hizmeti uygulamasını yapılandırın ve kodu dağıtın
App Services'e sağ tıklayın ve Yeni Web Uygulaması Oluştur'u seçin. Varsayılan olarak bir Linux konteyneri kullanılır.
Web uygulamanız için küresel olarak benzersiz bir ad yazın ve Enter'e basın. İsim, tüm Azure'da benzersiz olmalı ve yalnızca alfasayısal karakterler (
A-Z,a-zve0-9) ve kısa çizgi (-) kullanmalıdır.Çalışma zamanı yığını seç seçeneğinde, istediğiniz Node.js sürümünü seçin. Node 24 LTS önerilir.
Fiyatlandırma katmanı seçin bölümünde Ücretsiz (F1) öğesini seçin ve kaynakların Azure'da oluşturulmasını bekleyin.
Açılır pencerede "myExpressApp" çalışma alanını her zaman <app-name>" üzerine dağıtın seçeneğini işaretleyin ve Evet seçeneğini seçin. Bunu yapmak, aynı çalışma alanında olduğunuz sürece, Visual Studio Code her seferinde aynı App Service uygulamasına dağıtım yapmasını sağlar.
Visual Studio Code, Azure kaynaklarını oluşturup kodu dağıtırken, ilerleme bildirimlerini gösterir.
Dağıtım tamamlandıktan sonra bildirim açılır penceresinde Web Sitesine Gözat'ı seçin. Tarayıcı, Express varsayılan sayfasını görüntülemelidir.
Terminalde, myExpressApp dizininde olduğunuzdan emin olun ve kodu yerel klasörünüzdeki (myExpressApp) az webapp up komutunu kullanarak dağıtın.
az webapp up --sku F1 --name <app-name>
-
azkomutu tanınmadıysa, Başlangıç ortamınızı ayarlayın bölümünde açıklandığı gibi Azure CLI'nin yüklü olduğundan emin olun. - Azure genelinde benzersiz olan bir adla
<app_name>'i değiştirin. (Geçerli karakterlera-z,0-9ve-.) İyi bir desen, şirketinizin adıyla uygulama tanımlayıcısının bir birleşimini kullanmaktır. -
--sku F1argümanı, ücretsiz fiyatlandırma katmanında maliyetsiz olarak web uygulaması oluşturur. - İsteğe bağlı olarak
--location <location-name>argümanını,<location_name>geçerli bir Azure bölgesi olduğunda ekleyebilirsiniz. Azure hesabınız için izin verilen bölgelerin listesiniaz account list-locationskomutunu çalıştırarak alabilirsiniz. - Komut, varsayılan olarak Node.js için bir Linux uygulaması oluşturur. Bunun yerine bir Windows uygulaması oluşturmak için
--os-typeargümanını kullanın. - Eğer "Uygulamanızın çalışma zamanı yığını otomatik olarak algılanamadı" hatasını görüyorsanız, komutu myExpressApp dizininde çalıştırdığınızdan emin olun (bkz. az webapp up ile otomatik algılama sorunlarını giderme).
Komutun tamamlanması birkaç dakika sürebilir. Çalışma sırasında, kaynak grubunun, App Service planının ve uygulama kaynağının oluşturulması, günlük kaydının yapılandırılması ve Zip dağıtımı hakkında mesajlar sağlar. Ardından uygulamanın Azure'da URL'si olan URL'sini içeren bir ileti döndürür.
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 <URL>
{
"URL": "<URL>",
"appserviceplan": "<app-service-plan-name>",
"location": "centralus",
"name": "<app-name>",
"os": "<os-type>",
"resourcegroup": "<group-name>",
"runtime_version": "node|24",
"runtime_version_detected": "0.0",
"sku": "FREE",
"src_path": "/home/cephas/myExpressApp"
}
Uyarı
az webapp up komutu aşağıdaki eylemleri yapar:
Varsayılan bir kaynak grubu oluşturun.
Varsayılan bir App Service planı oluşturun.
Bir uygulama oluşturun belirtilen adla.
Zip dağıtım işlemini, yapı otomasyonu etkinleştirilmiş olarak, şu anki çalışma dizinindeki tüm dosyalar için yapın.
Parametreleri yerel olarak .azure/config dosyasında önbelleğe alın, böylece proje klasöründen
az webapp upveya diğeraz webappkomutlarıyla daha sonra dağıtırken bunları tekrar belirtmenize gerek kalmaz. Önbelleğe alınmış değerler varsayılan olarak otomatik kullanılır.
Azure kaynakları oluşturun
Azure portalınaoturum açın.
Node.js uygulaması oluşturmaya başlamak için https://portal.azure.com/#create/Microsoft.WebSite adresine gidin.
Temel Bilgiler sekmesinde, Proje Detayları altında, doğru aboneliğin seçili olduğundan emin olun ve ardından bir kaynak grubu oluşturmak için Yeni oluştur'u seçin. Ad olarak myResourceGroup yazın.
Örnek ayrıntıları altında, web uygulamanız için küresel olarak benzersiz bir ad yazın ve Kodu seçin. Çalışma Zamanı yığınındaNode 24 LTS, bir İşletim Sistemi ve uygulamanıza hizmet vermek istediğiniz bir Bölge'yi seçin.
Fiyatlandırma planları'nın altında Yeni oluştur'u seçerek App Service planı oluşturun. Ad olarak myAppServicePlan yazın. Ücretsiz katmanına geçmek için Fiyatlandırma planı listesinde Ücretsiz F1'i seçin.
Sayfanın altındaki İncele + oluştur düğmesini seçin.
Sayfa doğrulama çalışmaları tamamlandıktan sonra, sayfanın altındaki Oluştur düğmesine tıklayın.
Dağıtım tamamlandıktan sonra, Kaynağa git seçeneğini seçin.
FTPS kimlik bilgilerini al
Azure App Service, FTP/S dağıtımı için iki tür kimlik doğrulama bilgisi destekler. Bu kimlik bilgileri, Azure abonelik kimlik bilgilerinizle aynı değil. Bu bölümde, FTP istemcinizle kullanılacak uygulama kapsamı kimlik bilgilerini alırsınız.
App Service uygulaması sayfasında, kenar çubuğu menüsünde Dağıtım'ın altında Dağıtım Merkezi'ni seçin ve ardından FTPS Kimlik Bilgileri sekmesini seçin.
FTP istemcinizi açın ve myExpressApp klasörünüze gidin.
FTPS kimlik bilgileri sekmesinde FTPS uç noktasını, Kullanıcı Adını ve Parola'yı FTP istemcinize kopyalayın.
FTP istemcinizde Bağlan'ı seçin.
FTPS ile dosyaları dağıtın
Azure'da /site/wwwroot directory dizinine tüm dosyaları ve dizinleri kopyalayın.
Uygulamanızın URL'sini ziyaret ederek uygulamanın düzgün çalıştığını doğrulayın.
Güncellemeleri yeniden dağıt
Bu uygulama için değişiklikleri, Visual Studio Code'da düzenlemeler yaparak, dosyalarınızı kaydederek ve ardından Azure uygulamanıza yeniden dağıtarak yapabilirsiniz. Örneğin:
Örnek projeden views/index.ejs dosyasını açın ve değiştirin
<p>Welcome to <%= title %></p>için
<p>Welcome to Azure</p>
App Service gezgininde, Web Uygulamasına Yükle simgesini tekrar seçin ve Yükle'yi yeniden seçerek onaylayın.
Dağıtımın tamamlanmasını bekleyin, ardından bildirim açılır penceresinde Web Sitesine Gözat'ı seçin.
Welcome to ExpressiletisininWelcome to Azureolarak değiştirildiğini görmeniz gerekir.
Değişikliklerinizi kaydedin, ardından uygulamayı Linux için argümansız olarak tekrar az webapp up komutunu kullanarak yeniden dağıtın. Windows için
--os-type Windowsekle:az webapp upBu komut, uygulama adı, kaynak grubu ve Uygulama Hizmeti planı gibi yerel olarak .azure/config dosyasında önbelleğe alınmış değerleri kullanır.
Dağıtım tamamlandıktan sonra web sayfasını yenileyin.
Welcome to ExpressmesajınınWelcome to Azureolarak değiştirildiğini görebilmelisiniz.
Yaptığınız değişiklikleri kaydedin ve ardından uygulamayı FTP istemcinizi kullanarak yeniden dağıtın.
Dağıtım tamamlandıktan sonra web sayfasını yenileyin.
Welcome to ExpressmesajınınWelcome to Azureolarak değiştirildiğini görmelisiniz.
Akış günlükleri
Azure uygulamasından gelen günlük çıkışını (c0 /> çağrıları) doğrudan Visual Studio Code çıktı penceresinde yayınlayabilirsiniz.
Visual Studio Code'daki Kaynaklar'da uygulama düğümüne sağ tıklayın ve ardından Akış Günlüklerini Başlat'ı seçin.
Uygulamayı yeniden başlatmanız istenirse, Evet'i seçin. Uygulama yeniden başlatıldığında, Visual Studio Code çıktı penceresi günlük akışına bağlanarak açılır.
Birkaç saniye sonra, çıktı penceresi size günlük akışı hizmetine bağlı olduğunuzu belirten bir mesaj gösterir. Tarayıcıda sayfayı yenileyerek daha fazla çıktı etkinliği üretebilirsiniz.
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).
Uygulama içinden ve uygulamanın çalıştığı konteynerden üretilen konsol günlüklerine erişebilirsiniz. Çağrılar tarafından oluşturulan çıktıları içeren günlükler console.log() içerir.
Logları yayına almak için, az webapp log tail komutunu çalıştırın.
az webapp log tail
Komut, .azure/config dosyasında önbelleğe alınmış kaynak grup adını kullanır.
Dağıtım sırasında günlük akışını otomatik olarak açmak için --logs komutu ile birlikte parametresini de ekleyebilirsiniz.
Tarayıcıda uygulamayı yenileyin (refresh) ve uygulamaya yapılan HTTP isteklerini açıklayan mesajları içeren konsol günlüklerini (console logs) oluşturun. Hemen bir çıktı görünmezse, 30 saniye sonra tekrar deneyin.
Günlük akışını herhangi bir zamanda durdurmak için terminalde Ctrl+C'ye basın.
Uygulama içinden ve uygulamanın çalıştığı konteynerden üretilen konsol günlüklerine erişebilirsiniz. Node.js uygulamasından log çıktısını (console.log() ile yapılan çağrılar) doğrudan Azure portalında yayınlayabilirsiniz.
Uygulamanızın aynı App Service sayfasında, kenar çubuğu menüsünü kullanarak İzleme bölümüne gidin ve Günlük akışı'nı seçin.
Birkaç saniye sonra, çıktı penceresi size günlük akışı hizmetine bağlı olduğunuzu belirten bir mesaj gösterir. Tarayıcıda sayfayı yenileyerek daha fazla çıktı etkinliği üretebilirsiniz.
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 ---
Kaynakları temizle
Önceki adımlarda, bir kaynak grubunda Azure kaynakları oluşturdunuz. Bu ön başlangıçtaki adımlar, tüm kaynakları bu kaynak grubuna yerleştirir. Temizlik yapmak için, kaynak grubunu kaldırmanız yeterli.
Visual Studio Code'un Azure uzantısında, Gruplandır listesinde Kaynak Grubuna Göre Gruplandır'ı seçin.
Kaynaklar listesinde aboneliği genişletin, daha önce oluşturduğunuz kaynak grubuna sağ tıklayın ve ardından Kaynak Grubunu Sil'i seçin.
İstendiğinde, silmekte olduğunuz kaynak grubunun adını girerek silme işleminizi onaylayın. Onayladıktan sonra kaynak grubu silinir ve tamamlandığında bir bildirim görürsünüz.
Önceki adımlarda, bir kaynak grubunda Azure kaynakları oluşturdunuz. Kaynak grubunun konumunuza bağlı olarak appsvc_rg_Linux_CentralUS gibi bir adı vardır.
Gelecekte bu kaynaklara ihtiyacınız olmayacağını düşünüyorsanız, aşağıdaki komutu çalıştırarak kaynak grubunu silin:
az group delete --no-wait
Komut, .azure/config dosyasında önbelleğe alınmış kaynak grup adını kullanır.
--no-wait argümanı, işlemin tamamlanmasından önce komutun geri dönmesine olanak tanır.
Kaynak grubu, uygulama hizmeti ve ilgili tüm kaynaklar artık gerekli olmadığında silinebilir.
Uygulama Hizmeti genel bakış sayfanızdan Azure kaynakları oluştur adımında oluşturduğunuz kaynak grubunu seçin.
Kaynak grubu sayfasından Kaynak grubunu sil öğesini seçin. Kaynakları silmeyi tamamlamak için kaynak grubunun adını doğrulayın.
İlgili içerik
Tebrikler, hızlı başlangıcı başarıyla tamamladınız!
Diğer Azure uzantılarına göz atın.
- Azure Cosmos DB
- Azure İşlevleri
- Docker Uzantı Paketi
- Azure CLI Araçları
- Azure Resource Manager Araçları
Tümünü Azure için Node Paketi uzantı paketini yükleyerek edinin.