Hızlı Başlangıç: Azure Spring Apps uygulamalarını günlükler, ölçümler ve izleme ile izleme
Not
Azure Spring Apps, Azure Spring Cloud hizmetinin yeni adıdır. Hizmetin yeni bir adı olsa da, ekran görüntüleri, videolar ve diyagramlar gibi varlıkları güncelleştirmek için çalışırken bazı yerlerde eski adı bir süre görürsünüz.
Bu makale şunlar için geçerlidir: ✔️ Temel/Standart ❌ Kurumsal
Azure Spring Apps'teki yerleşik izleme özelliğiyle karmaşık sorunların hatalarını ayıklayabilir ve izleyebilirsiniz. Azure Spring Apps, Steeltoe dağıtılmış izlemeyi Azure'ın Application Analizler ile tümleştirir. Bu tümleştirme, Azure portalından güçlü günlükler, ölçümler ve dağıtılmış izleme özelliği sağlar.
Aşağıdaki yordamlarda, önceki hızlı başlangıçlarda dağıttığınız örnek uygulamayla Log Streaming, Log Analytics, Metrics ve Distributed Tracing'in nasıl kullanılacağı açıklanmaktadır.
Önkoşullar
Bu serideki önceki hızlı başlangıçları tamamlayın:
- Azure Spring Apps hizmet örneği sağlama.
- Hızlı Başlangıç: Azure Spring Apps için Spring Cloud Config Server'i ayarlama.
- Uygulamaları derleme ve Azure Spring Apps'e dağıtma.
- Log Analytics çalışma alanı ayarlayın.
Günlükler
Azure Spring Apps'te günlükleri görmenin iki yolu vardır: Uygulama örneği başına gerçek zamanlı günlüklerin Günlük Akışı veya gelişmiş sorgu özelliğine sahip toplu günlükler için Log Analytics .
Günlük akışı
Azure CLI'da günlük akışını aşağıdaki komutla kullanabilirsiniz.
az spring app logs --name solar-system-weather --follow
Aşağıdaki örneğe benzer bir çıkış gösterilir:
=> ConnectionId:0HM2HOMHT82UK => RequestPath:/weatherforecast RequestId:0HM2HOMHT82UK:00000003, SpanId:|e8c1682e-46518cc0202c5fd9., TraceId:e8c1682e-46518cc0202c5fd9, ParentId: => Microsoft.Azure.SpringCloud.Sample.SolarSystemWeather.Controllers.WeatherForecastController.Get (Microsoft.Azure.SpringCloud.Sample.SolarSystemWeather)
Executing action method Microsoft.Azure.SpringCloud.Sample.SolarSystemWeather.Controllers.WeatherForecastController.Get (Microsoft.Azure.SpringCloud.Sample.SolarSystemWeather) - Validation state: Valid
←[40m←[32minfo←[39m←[22m←[49m: Microsoft.Azure.SpringCloud.Sample.SolarSystemWeather.Controllers.WeatherForecastController[0]
=> ConnectionId:0HM2HOMHT82UK => RequestPath:/weatherforecast RequestId:0HM2HOMHT82UK:00000003, SpanId:|e8c1682e-46518cc0202c5fd9., TraceId:e8c1682e-46518cc0202c5fd9, ParentId: => Microsoft.Azure.SpringCloud.Sample.SolarSystemWeather.Controllers.WeatherForecastController.Get (Microsoft.Azure.SpringCloud.Sample.SolarSystemWeather)
Retrieved weather data from 4 planets
←[40m←[32minfo←[39m←[22m←[49m: Microsoft.AspNetCore.Mvc.Infrastructure.ControllerActionInvoker[2]
=> ConnectionId:0HM2HOMHT82UK => RequestPath:/weatherforecast RequestId:0HM2HOMHT82UK:00000003, SpanId:|e8c1682e-46518cc0202c5fd9., TraceId:e8c1682e-46518cc0202c5fd9, ParentId: => Microsoft.Azure.SpringCloud.Sample.SolarSystemWeather.Controllers.WeatherForecastController.Get (Microsoft.Azure.SpringCloud.Sample.SolarSystemWeather)
Executing ObjectResult, writing value of type 'System.Collections.Generic.KeyValuePair`2[[System.String, System.Private.CoreLib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=7cec85d7bea7798e],[System.String, System.Private.CoreLib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=7cec85d7bea7798e]][]'.
←[40m←[32minfo←[39m←[22m←[49m: Microsoft.AspNetCore.Mvc.Infrastructure.ControllerActionInvoker[2]
İpucu
Daha fazla parametreyi ve günlük akışı işlevini keşfetmek için kullanın az spring app logs -h
.
Log Analytics
Azure portalında hizmete gidin | Genel bakış sayfası ve İzleme bölümünde Günlükler'iseçin. Azure Spring Apps için örnek sorgulardan birinde çalıştır'ı seçin.
Görüntüyü uyarı ve hata günlükleriyle sınırlayan Where yan tümcelerini kaldırmak için sorguyu düzenleyin.
Çalıştır seçin. Günlükler gösterilir. Daha fazla bilgi için bkz . Azure İzleyici'de günlük sorgularını kullanmaya başlama.
Log Analytics'te kullanılan sorgu dili hakkında daha fazla bilgi edinmek için bkz . Azure İzleyici günlük sorguları. Merkezi bir istemciden tüm Log Analytics günlüklerinizi sorgulamak için Bkz. Azure Veri Gezgini.
Ölçümler
Azure portalında hizmete gidin | Genel bakış sayfası ve İzleme bölümünde Ölçümler'iseçin. Ölçüm açılan listesinde Performans (.NET) veya İstek (.NET) altında .NET ölçümlerinden birini seçerek ilk ölçümünüzü ekleyin ve bu ölçümün zaman çizelgesini görmek için Toplama için Ortalama'yı seçin.
Araç çubuğunda Filtre ekle'yi seçin ve yalnızca güneş sistemi-hava durumu uygulaması için CPU kullanımını görmek için seçin
App=solar-system-weather
.Önceki adımda oluşturulan filtreyi kapatıp Bölme Uygula'yı seçin ve farklı uygulamaların CPU kullanımını görmek için Değerler için Uygulama'yı seçin.
Dağıtılmış izleme
Azure portalında hizmete gidin | Genel bakış sayfası ve İzleme bölümünde Dağıtılmış izleme'yiseçin. Ardından sağ taraftaki Uygulama haritasını görüntüle sekmesini seçin.
Artık uygulamalar arasındaki çağrıların durumunu görebilirsiniz.
HTTP yöntemlerinin en yavaş çağrıları gibi diğer ayrıntıları görmek için güneş sistemi-hava durumu ve gezegen-hava durumu sağlayıcısı arasındaki bağlantıyı seçin.
Son olarak, daha güçlü yerleşik performans analizini keşfetmek için Performansı Araştır'ı seçin.
Azure Spring Apps'teki yerleşik izleme özelliğiyle karmaşık sorunların hatalarını ayıklayabilir ve izleyebilirsiniz. Azure Spring Apps, Spring Cloud Sleuth'u Azure'ın Application Analizler ile tümleştirir. Bu tümleştirme, Azure portalından güçlü günlükler, ölçümler ve dağıtılmış izleme özelliği sağlar. Aşağıdaki yordamlarda Dağıtılan PetClinic uygulamalarıyla Log Streaming, Log Analytics, Metrics ve Distributed izlemenin nasıl kullanılacağı açıklanmaktadır.
Önkoşullar
Bu serideki önceki hızlı başlangıçları tamamlayın:
- Azure Spring Apps hizmet örneği sağlama.
- Hızlı Başlangıç: Azure Spring Apps için Spring Cloud Config Server'i ayarlama.
- Uygulamaları derleme ve Azure Spring Apps'e dağıtma.
- Log Analytics çalışma alanı ayarlayın.
Günlükler
Azure Spring Apps'te günlükleri görmenin iki yolu vardır: Uygulama örneği başına gerçek zamanlı günlüklerin Günlük Akışı veya gelişmiş sorgu özelliğine sahip toplu günlükler için Log Analytics .
Günlük akışı
Azure CLI'da günlük akışını aşağıdaki komutla kullanabilirsiniz.
az spring app logs \
--resource-group <resource-group-name> \
--service <service-instance-name> \
--name api-gateway \
--follow
Size aşağıdaki gibi günlükler gösterilir:
İpucu
Daha fazla parametreyi ve günlük akışı işlevini keşfetmek için kullanın az spring app logs -h
.
Log Analytics'te kullanılan sorgu dili hakkında daha fazla bilgi edinmek için bkz . Azure İzleyici günlük sorguları. Merkezi bir istemciden tüm Log Analytics günlüklerinizi sorgulamak için Bkz. Azure Veri Gezgini.
Log Analytics
Hizmete git | Genel bakış sayfası ve İzleme bölümünde Günlükler'iseçin. Azure Spring Apps için örnek sorgulardan birinde çalıştır'ı seçin.
Ardından filtrelenmiş günlükler gösterilir. Daha fazla bilgi için bkz . Azure İzleyici'de günlük sorgularını kullanmaya başlama.
Ölçümler
Application insights sayfasına gidin ve ardından Ölçümler sayfasına gidin. Spring Boot uygulamalarının, Spring modüllerinin ve bağımlılıkların katkıda bulunduğu ölçümleri görebilirsiniz.
Aşağıdaki grafikte (Spring Cloud Gateway), hikaricp_connections
(JDBC Bağlan ions) ve http_client_requests
gösterilmektedir gateway_requests
.
Spring Boot, JVM, CPU, Tomcat ve Logback gibi çeşitli temel ölçümleri kaydeder. Spring Boot otomatik yapılandırması, Spring MVC tarafından işlenen isteklerin izlemesini sağlar. Üç REST denetleyicisi de (OwnerResource
, PetResource
ve VisitResource
) sınıf düzeyinde Mikrometre ek açıklaması tarafından @Timed
izlenir.
Uygulamada customers-service
aşağıdaki özel ölçümler etkindir:
- @Timed:
petclinic.owner
- @Timed:
petclinic.pet
Uygulamada visits-service
aşağıdaki özel ölçümler etkindir:
- @Timed:
petclinic.visit
Bu özel ölçümleri Ölçümler sayfasında görebilirsiniz:
Uygulama Analizler'nde Kullanılabilirlik Testi özelliğini kullanabilir ve uygulamaların kullanılabilirliğini izleyebilirsiniz:
Canlı ölçümleri düşük gecikme süresiyle (bir saniyeden kısa) görmek için Canlı Ölçümler sayfasına gidin:
İzleme
Azure Spring Apps tarafından oluşturulan Uygulama Analizler açın ve Spring uygulamalarını izlemeye başlayın.
Uygulama Haritası sayfasına gidin:
Performans sayfasına gidin:
Bağımlılıklar sekmesine gidin ve bağımlılıkların performans numarasını , özellikle SQL çağrılarını görebilirsiniz:
Bağlam içinde uçtan uca işlemi görmek için bir SQL çağrısı seçin:
Hatalar sayfasına ve Özel Durumlar sekmesine gidin; burada özel durumlar koleksiyonunu görebilirsiniz:
Bağlam içinde uçtan uca işlemi ve yığın izlemesini görmek için bir özel durum seçin:
Kaynakları temizleme
Sonraki hızlı başlangıçlar ve öğreticilerle çalışmaya devam etmek istiyorsanız, bu kaynakları yerinde bırakmak isteyebilirsiniz. Artık gerekli olmadığında kaynak grubunu silin; bu da kaynak grubundaki kaynakları siler. Azure CLI kullanarak kaynak grubunu silmek için aşağıdaki komutları kullanın:
echo "Enter the Resource Group name:" &&
read resourceGroupName &&
az group delete --name $resourceGroupName &&
echo "Press [ENTER] to continue ..."
Önceki bir hızlı başlangıçta varsayılan kaynak grubu adını da ayarlamıştınız. Sonraki hızlı başlangıca devam etmek istemiyorsanız, aşağıdaki CLI komutunu çalıştırarak bu varsayılanı temizleyin:
az config set defaults.group=
Sonraki adımlar
Azure Spring Apps'in daha fazla izleme özelliklerini keşfetmek için bkz:
Geri Bildirim
https://aka.ms/ContentUserFeedback.
Çok yakında: 2024 boyunca, içerik için geri bildirim mekanizması olarak GitHub Sorunları’nı kullanımdan kaldıracak ve yeni bir geri bildirim sistemiyle değiştireceğiz. Daha fazla bilgi için bkz.Gönderin ve geri bildirimi görüntüleyin