Bu sayfada, Performance Monitoring'yı kullanmaya başlama veya Performance Monitoring özelliklerini ve araçlarını kullanma ile ilgili sorun giderme ipuçları verilmektedir.
Sorun giderme için ilk kontroller
Aşağıdaki iki kontrol, daha fazla sorun gidermeye başlamadan önce herkese önerilen genel en iyi uygulamalardır.
1. Performans olayları için günlük mesajlarını kontrol edin
Performance Monitoring SDK'sının performans olaylarını yakaladığından emin olmak için günlük mesajlarınızı kontrol edin.
Performans olaylarına ilişkin günlük mesajları nasıl görüntülenir?
Uygulamanızın
AndroidManifest.xmldosyasına şu şekilde bir<meta-data>öğesi ekleyerek derleme zamanında Performance Monitoring için hata ayıklama günlüğünü etkinleştirin:<application> <meta-data android:name="firebase_performance_logcat_enabled" android:value="true" /> </application>Herhangi bir hata mesajı olup olmadığını görmek için günlük mesajlarınızı kontrol edin.
Performance Monitoring, günlük mesajlarını
FirebasePerformanceile etiketler. Logcat filtrelemesini kullanarak, aşağıdaki komutu çalıştırarak süre izini ve HTTP/S ağ isteği günlüğünü özel olarak görüntüleyebilirsiniz:adb logcat -s FirebasePerformance
Performance Monitoring'nın performans etkinliklerini günlüğe kaydettiğini gösteren aşağıdaki günlük türlerini kontrol edin:
Logging trace metric: TRACE_NAME, FIREBASE_PERFORMANCE_CONSOLE_URLLogging network request trace: URL
Verilerinizi Firebase konsolunda görüntülemek için URL'yi tıklayın. Gösterge tablosundaki verilerin güncellenmesi birkaç dakika sürebilir.
Uygulamanız performans olaylarını kaydetmiyorsa sorun giderme ipuçlarını inceleyin.
2. Firebase Durum Kontrol Paneli'ni kontrol edin.
Firebase veya Performance Monitoring için bilinen bir kesinti olması durumunda Firebase Durum Kontrol Paneli'ni kontrol edin.
Performance Monitoring'ı kullanmaya başlama
Performance Monitoring (iOS+ | Android | Web) ile çalışmaya başlıyorsanız aşağıdaki sorun giderme ipuçları, Firebase'in SDK'yı algılaması veya ilk performans verilerinizi Firebase konsolunda göstermesiyle ilgili sorunlara yardımcı olabilir.
SDK uygulamaya eklendi ancak konsolda hala SDK'nın eklenmesi gerektiği belirtiliyor
Firebase, uygulamanızdan etkinlik bilgileri (ör. uygulama etkileşimleri) aldığında Performance Monitoring SDK'yı uygulamanıza başarıyla ekleyip eklemediğinizi algılayabilir. Genellikle uygulamanızı başlattıktan sonraki 10 dakika içinde Firebase konsolunun Performans kontrol panelinde "SDK algılandı" mesajı gösterilir. Ardından, 30 dakika içinde kontrol panelinde ilk işlenen veriler gösterilir.
SDK'nın en son sürümünü uygulamanıza eklemenizin üzerinden 10 dakikadan fazla zaman geçtiyse ve hâlâ herhangi bir değişiklik görmüyorsanız Performance Monitoring öğesinin etkinlikleri kaydettiğinden emin olmak için günlük mesajlarınızı kontrol edin. Gecikmeli SDK algılama mesajıyla ilgili sorunları gidermek için aşağıda açıklanan uygun sorun giderme adımlarını deneyin.
Uygulama etkinlikleri günlüğe kaydediyor: sorun giderme adımları
Performance Monitoring Android SDK 19.1.0 veya sonraki sürümünü (veya Firebase BoM 26.3.0 veya sonraki sürümünü) kullandığınızdan emin olun, bkz. Sürüm Notu.
Hala yerel olarak geliştirme yapıyorsanız, veri toplama için daha fazla etkinlik oluşturmayı deneyin:
- Uygulamanızı arka plan ve ön plan arasında birkaç kez değiştirerek, ekranlar arasında gezinerek uygulamanızla etkileşim kurarak ve/veya ağ isteklerini tetikleyerek olaylar oluşturun.
Firebase yapılandırma dosyanızın (
google-services.json) uygulamanıza doğru şekilde eklendiğinden ve dosyayı değiştirmediğinizden emin olun. Özellikle aşağıdakileri kontrol edin:Yapılandırma dosyası adına
(2)gibi ek karakterler eklenmez.Yapılandırma dosyası uygulamanızın module (app-level) dizinindedir.
Yapılandırma dosyasında listelenen Firebase Android Uygulama Kimliği (
mobilesdk_app_id), uygulamanız için doğrudur. Firebase Uygulama Kimliğinizi, settings Proje ayarlarınızdaki Uygulamalarınız kartında bulabilirsiniz.
Uygulamanızdaki yapılandırma dosyasında herhangi bir sorun varsa aşağıdakileri deneyin:
Uygulamanızda şu anda bulunan yapılandırma dosyasını silin.
Yeni bir yapılandırma dosyası indirmek ve bunu Android uygulamanıza eklemek için bu talimatları izleyin.
SDK olayları günlüğe kaydediyorsa ve her şey doğru şekilde ayarlanmış gibi görünüyorsa ancak yine de SDK algılama mesajını veya işlenmiş verileri görmüyorsanız (10 dakika sonra), Firebase Desteği ile iletişime geçin.
Uygulama etkinlikleri kaydetmiyor: sorun giderme adımları
Performance Monitoring Gradle eklentisinin kurulumunu aşağıdaki şekilde kontrol edin:
Eklentiyi doğru şekilde eklediğinizden emin olun. Özellikle aşağıdakileri kontrol edin:
- Eklentiyi (
) modülünüzdeki (uygulama düzeyinde)apply plugin: 'com.google.firebase.firebase-perf' build.gradledosyasına eklediniz. - Eklenti (
) için sınıf yolu bağımlılığını proje düzeyiclasspath 'com.google.firebase:perf-plugin:2.0.2' build.gradledosyanıza eklediniz.
- Eklentiyi (
Aşağıdaki işaretlerden herhangi biri aracılığıyla eklentinin devre dışı bırakılmadığından emin olun:
- Modülünüzdeki (uygulama düzeyi)
build.gradledosyasındainstrumentationEnabled firebasePerformanceInstrumentationEnabledgradle.propertiesdosyanızda
- Modülünüzdeki (uygulama düzeyi)
Performance Monitoring SDK'sının devre dışı bırakılmadığını
AndroidManifest.xmldosyanızdaki aşağıdaki işaretlerden biriyle kontrol edin:firebase_performance_collection_enabledfirebase_performance_collection_deactivated
Performance Monitoring öğesinin çalışma zamanında devre dışı bırakılmadığından emin olun.
Uygulamanızda devre dışı bırakılmış bir şey bulamıyorsanız Firebase Destek Ekibi ile iletişime geçin.
Konsol, SDK'nın algılandığını belirtiyor ancak veri gösterilmiyor
Performance Monitoring, performans etkinliği verilerini Performans kontrol panelinde göstermeden önce işler.
"SDK algılandı" mesajının görünmesinden bu yana 24 saatten uzun bir süre geçtiyse ve hâlâ veri görmüyorsanız bilinen bir kesinti olup olmadığını kontrol etmek için Firebase Durum Kontrol Paneli'ne bakın. Kesinti yoksa Firebase Destek Ekibi ile iletişime geçin.
Genel sorun giderme
SDK'yı başarıyla eklediyseniz ve uygulamanızda Performance Monitoring kullanıyorsanız aşağıdaki sorun giderme ipuçları, Performance Monitoring özellikleri ve araçlarıyla ilgili genel sorunlara yardımcı olabilir.
Uygulama, performans etkinliklerini günlüğe kaydetmiyor
Performans etkinlikleriyle ilgili günlük mesajlarını görmüyorsanız aşağıdaki sorun giderme adımlarını deneyin:
Performance Monitoring Gradle eklentisinin kurulumunu aşağıdaki şekilde kontrol edin:
Eklentiyi doğru şekilde eklediğinizden emin olun. Özellikle aşağıdakileri kontrol edin:
- Eklentiyi (
) modülünüzdeki (uygulama düzeyinde)apply plugin: 'com.google.firebase.firebase-perf' build.gradledosyasına eklediniz. - Eklentinin sınıf yolu bağımlılığını (
) proje düzeyindekiclasspath 'com.google.firebase:perf-plugin:2.0.2' build.gradledosyanıza eklediniz.
- Eklentiyi (
Aşağıdaki işaretlerden herhangi biri aracılığıyla eklentinin devre dışı bırakılmadığından emin olun:
instrumentationEnabledmodülünüzde (uygulama düzeyinde)build.gradledosyasıfirebasePerformanceInstrumentationEnabledgradle.propertiesdosyanızda
Performance Monitoring SDK'sının devre dışı bırakılmadığını
AndroidManifest.xmldosyanızdaki aşağıdaki işaretlerden biriyle kontrol edin:firebase_performance_collection_enabledfirebase_performance_collection_deactivated
Performance Monitoring öğesinin çalışma zamanında devre dışı bırakılmadığından emin olun.
Uygulamanızda devre dışı bırakılmış bir şey bulamıyorsanız Firebase Destek Ekibi ile iletişime geçin.
Performans kontrol panelinde ekran izi verileri eksik
Ekran oluşturma izleriyle ilgili verileriniz eksikse aşağıdaki sorun giderme adımlarını deneyin:
Android SDK'nın en son sürümünü (v22.0.3) kullandığınızdan emin olun. Ekran oluşturma izleri yalnızca v15.2.0 veya sonraki sürümlerde kullanılabilir.
Bir ekran için Donanım Hızlandırma'yı manuel olarak devre dışı bırakmadığınızdan emin olun.
DexGuard veya Jack kullanmadığınızdan emin olun. Performance Monitoring bu araç zincirleriyle uyumlu değil.
DexGuard, uygulama başlangıcı, uygulama ön planda ve uygulama arka planda izlerinin otomatik olarak toplanmasını devre dışı bırakır. Ancak, uygulamanız DexGuard kullanıyorsa tüm özel kod izleri normal şekilde davranmalıdır.
Jack desteği sonlandırıldı ve genellikle uygulamanızda kullanılmamalıdır.
Performans panosunda özel izleme verileri eksik
Otomatik olarak toplanan izler için performans verilerini görüyor musunuz ancak özel kod izleri için görmüyor musunuz? Aşağıdaki sorun giderme adımlarını deneyin:
Trace API aracılığıyla özel kod izlemeleri oluşturduysanız izlemelerin kurulumunu, özellikle de aşağıdakileri kontrol edin:
- Özel kod izlemelerinin ve özel metriklerin adları aşağıdaki koşulları karşılamalıdır: başta veya sonda boşluk olmamalıdır, başta alt çizgi (
_) karakteri olmamalıdır ve maksimum uzunluk 32 karakterdir. - Tüm izlerin başlatılması ve durdurulması gerekir. Başlatılmayan, durdurulmayan veya başlamadan önce durdurulan hiçbir iz kaydedilmeyecektir.
- Özel kod izlemelerinin ve özel metriklerin adları aşağıdaki koşulları karşılamalıdır: başta veya sonda boşluk olmamalıdır, başta alt çizgi (
Özel kod izlemelerini
@AddTracenotasyonu ile oluşturduysanız Performance Monitoring Gradle eklentisinin kurulumunu kontrol edin:Eklentiyi doğru şekilde eklediğinizden emin olun. Özellikle aşağıdakileri kontrol edin:
- Eklentiyi (
) modülünüzdeki (uygulama düzeyinde)apply plugin: 'com.google.firebase.firebase-perf' build.gradledosyasına eklediniz. - Eklenti (
) için sınıf yolu bağımlılığını proje düzeyiclasspath 'com.google.firebase:perf-plugin:2.0.2' build.gradledosyanıza eklediniz.
- Eklentiyi (
Aşağıdaki işaretlerden herhangi biri aracılığıyla eklentinin devre dışı bırakılmadığından emin olun:
- Modülünüzdeki (uygulama düzeyi)
build.gradledosyasındainstrumentationEnabled gradle.propertiesdosyanızdafirebasePerformanceInstrumentationEnabled
- Modülünüzdeki (uygulama düzeyi)
Performance Monitoring'nin beklenen özel kod izlerini kaydettiğinden emin olmak için günlük mesajlarınızı kontrol edin.
Performance Monitoring etkinlikleri kaydediyor ancak 24 saat sonra veri görüntülenmiyorsa Firebase Destek Ekibi ile iletişime geçin.
Performans gösterge tablosunda ağ isteği verileri eksik
Ağ isteği verileriniz eksikse aşağıdaki sorun giderme adımlarını deneyin:
Android uygulamaları için Performance Monitoring Gradle eklentisi, HTTP/S ağ isteklerinin otomatik olarak izlenmesini sağlayan enstrümantasyonu etkinleştirir. Aşağıdakileri kontrol edin:
Eklentiyi doğru şekilde eklediğinizden emin olun. Özellikle aşağıdakileri kontrol edin:
- Eklentiyi (
) modülünüzdeki (uygulama düzeyinde)apply plugin: 'com.google.firebase.firebase-perf' build.gradledosyasına eklediniz. - Eklentinin sınıf yolu bağımlılığını (
) proje düzeyindekiclasspath 'com.google.firebase:perf-plugin:2.0.2' build.gradledosyanıza eklediniz.
- Eklentiyi (
Aşağıdaki işaretlerden herhangi biri aracılığıyla eklentinin devre dışı bırakılmadığından emin olun:
instrumentationEnabledmodülünüzde (uygulama düzeyinde)build.gradledosyasıfirebasePerformanceInstrumentationEnabledgradle.propertiesdosyanızda
Ağ kitaplığı uyumsuzluğunu kontrol edin. Performance Monitoring Aşağıdaki ağ iletişimi kitaplıklarını kullanan ağ istekleriyle ilgili metrikleri otomatik olarak toplar: OkHttp 3.x.x, Java'nın URLConnection'ı ve Apache HttpClient.
Aşağıdakilere dikkat edin:
Kodunuzun davranışına ve kodunuz tarafından kullanılan ağ kitaplıklarına bağlı olarak, Performance Monitoring yalnızca tamamlanan ağ isteklerini raporlayabilir. Bu nedenle, açık bırakılan HTTP/S bağlantıları raporlanmayabilir.
Performance Monitoring, DexGuard ve Jack ile uyumlu değildir.
- DexGuard, HTTP/S ağ isteklerinin izlenmesini devre dışı bırakır.
- Jack desteği sonlandırıldı ve genellikle uygulamanızda kullanılmamalıdır.
Performance Monitoring, geçersiz
Content-Typeüstbilgileri içeren ağ istekleri hakkında rapor oluşturmaz. AncakContent-Typebaşlıkları olmayan ağ istekleri yine de kabul edilecektir.
Ağ isteği verileri beklendiği gibi toplanmıyor
URL kalıpları altında Performance Monitoring'in ağ isteği verilerini nasıl topladığı hakkında daha fazla bilgi edinin.
Özel URL kalıplarını da deneyebilirsiniz.
SSS
Project Home'daki Performans kartındaki En Önemli Konular'a ne oldu?
Son zamanlarda kullanıma sunduğumuz uyarılar özelliğinin devamı olarak En Önemli Sorunlar bölümünü Son Uyarılar ile değiştirdik. Bu özellik, belirlediğiniz eşikler aşıldığında sizi otomatik olarak bilgilendirir. Sorunlar artık kullanımdan kaldırıldı ve bunların yerini uyarılar aldı.
Performans kartının üst kısmındaki uygulama seçici, Son Uyarılar altındaki uyarı girişlerini filtreler. Yalnızca seçilen uygulamalarla ilgili en son üç uyarı gösterilir.
Uyarılar hakkında daha fazla bilgi edinmek için Performans sorunlarıyla ilgili uyarıları ayarlama başlıklı makaleyi inceleyin.
Konsolda sorunlar için eşik belirleme yeteneğine ne oldu?
Performance Monitoring, tanımlanan eşikleri aşan metrikler için uyarıları destekler. Performans ölçümleri için bu yapılandırılabilir eşiklerle ilgili karışıklığı önlemek amacıyla, sorunlar için eşik yapılandırma özelliğini kaldırdık.
Firebase konsolundaki Ayrıntılar ve Metrikler bilgilerine ne oldu?
Sorun giderme yönteminizi iyileştirmek için Ayrıntılar ve Ölçümler sayfalarını yeni tasarlanmış, merkezi bir kullanıcı arayüzü (UI) ile değiştirdik. Bu yeni sorun giderme kullanıcı arayüzü, Ayrıntılar ve Ölçümler'in sunduğu aynı temel işlevselliği sunar. Sorun giderme hakkında daha fazla bilgi edinmek için Belirli bir izleme için daha fazla veri görüntüleme başlıklı makaleyi inceleyin.
Neden örnek sayısı beklediğim gibi değil?
Performance Monitoring, uygulamanızın kullanıcı cihazlarından performans verilerini toplar. Uygulamanızın çok sayıda kullanıcısı varsa veya uygulama büyük miktarda performans etkinliği oluşturuyorsa Performance Monitoring, işlenen etkinlik sayısını azaltmak için veri toplamayı cihazların bir alt kümesiyle sınırlayabilir. Bu sınırlar o kadar yüksektir ki, daha az etkinlik olsa bile metrik değerleri kullanıcınızın uygulama deneyimini temsil etmeye devam eder.
Topladığımız veri hacmini yönetmek için Performance Monitoring aşağıdaki örnekleme seçeneklerini kullanır:
Cihaz üzerinde sıklık sınırlaması: Bir cihazın ani izleme dizileri göndermesini önlemek için bir cihazdan gönderilen kod ve ağ isteği izlerinin sayısını 10 dakikada 300 etkinlik ile sınırlandırırız. Bu yaklaşım, cihazı büyük miktarda performans verisi gönderebilen döngüye alınmış enstrümantasyonlardan korur ve tek bir cihazın performans ölçümlerini çarpıtmasını önler.
Dinamik örnekleme: Performance Monitoring, tüm uygulama kullanıcıları genelinde günlük olarak uygulama başına sınırlı sayıda kod izi ve ağ isteği izi toplar. Rastgele bir cihazın izleri yakalayıp göndermesi gerekip gerekmediğini belirlemek için cihazlarda dinamik bir örnekleme oranı alınır (Firebase Remote Config kullanılarak). Örnekleme için seçilmeyen bir cihaz herhangi bir olay göndermez. Dinamik örnekleme oranı uygulamaya özgüdür ve toplanan verilerin genel hacminin sınırın altında kalmasını sağlamak için ayarlanır.
BigQuery entegrasyonunu etkinleştiren projeler, ağ isteği izlerinin sayısı için daha yüksek bir sınır alır.
Kullanıcı oturumları, kullanıcının cihazından ek, ayrıntılı veriler gönderir ve bu da verileri yakalamak ve göndermek için daha fazla kaynak gerektirir. Kullanıcı oturumlarının etkisini en aza indirmek için Performance Monitoring oturum sayısını da kısıtlayabilir.
Sunucu tarafı sıklık sınırlaması: Uygulamaların örnekleme sınırını aşmaması için Performance Monitoring, cihazlardan alınan bazı etkinlikleri bırakmak üzere sunucu tarafı örnekleme kullanabilir. Bu tür bir sınırlama, metriklerimizin etkinliğini değiştirmese de aşağıdakiler de dahil olmak üzere küçük kalıp değişikliklerine neden olabilir:
- İz sayısı, bir kod parçasının yürütülme sayısından farklı olabilir.
- Kodda sıkı bir şekilde bağlı olan izlerin her birinde farklı sayıda örnek olabilir.
Konsoldaki Sorunlar sekmesine ne oldu?
Sorunlar sekmesinin yerini, belirlediğiniz eşikler aşıldığında sizi otomatik olarak bilgilendiren Uyarılar aldı. Eşiğin durumunu belirlemek için artık Firebase konsolunu manuel olarak kontrol etmeniz gerekmez. Uyarılar hakkında bilgi edinmek için Performans sorunları için uyarıları ayarlama konusuna bakın.
Konsoldaki Cihazda ve Ağ sekmelerine ne oldu? Bu sayfalardaki izleri nasıl görüntüleyebilirim?
Firebase konsolunun Performance Monitoring bölümünü yeniden tasarladık. Böylece Kontrol Paneli sekmesinde, önemli metrikleriniz ve tüm izleriniz tek bir alanda gösteriliyor. Yeniden tasarım kapsamında Cihazda ve Ağ sayfalarını kaldırdık.
Gösterge tablosu sekmesinin alt kısmındaki izler tablosunda, Cihazda ve Ağ sekmelerinde gösterilen tüm bilgiler yer alır. Ancak bu tabloda, izlerinizi belirli bir metriğin yüzde değişimine göre sıralama özelliği de dahil olmak üzere bazı ek özellikler bulunur. Belirli bir izlemeye ait tüm metrikleri ve verileri görüntülemek için izlemeler tablosunda izleme adını tıklayın.
İzleme tablosunun aşağıdaki alt sekmelerinde izlemelerinizi görüntüleyin:
- Ağ isteği izleri (hem kullanıma hazır hem de özel) — Ağ istekleri alt sekmesi
- Özel kod izleri: Özel izler alt sekmesi
- Uygulama başlatma, uygulama ön planda, uygulama arka planda izleri: Özel izler alt sekmesi
- Ekran oluşturma izleri: Ekran oluşturma alt sekmesi
- Sayfa yükleme izleri — Sayfa yükleme alt sekmesi
İzlemeler tablosu ve metrikleri ile verileri görüntüleme hakkında ayrıntılı bilgi için konsola genel bakış sayfasını ziyaret edin (iOS+ | Android | Web).
Yavaş ve donmuş karelerin sayısı neden beklediğim gibi değil?
Yavaş oluşturma kareleri ve donmuş kareler, cihazın yenileme hızının 60 Hz olduğu varsayılarak hesaplanır. Bir cihazın yenileme hızı 60 Hz'den düşükse saniyede daha az kare oluşturulduğu için her karenin oluşturma süresi daha yavaş olur. Daha yavaş oluşturma süreleri, daha fazla karenin yavaş oluşturulmasına veya donmasına neden olacağından daha fazla yavaş veya donmuş kare bildirilmesine neden olabilir. Ancak bir cihazın yenileme hızı 60 Hz'den yüksekse her karenin oluşturma süresi daha hızlı olur. Bu durum, daha az sayıda yavaş veya donmuş karenin bildirilmesine neden olabilir. Bu, Performance Monitoring SDK'daki mevcut bir sınırlamadır.
Neden parça izlerini göremiyorum?
Uygulama etkinliğinin yanı sıra parçaların performansını da görmek için uygulamanızın Performance Monitoring Android SDK'nın 20.1.0 veya sonraki bir sürümünü kullandığından emin olun. Daha fazla bilgi edinmek için Uygulamanıza Performance Monitoring ekleme başlıklı makaleyi inceleyin.
Hangi izlerin parçalar ve etkinliklerle ilgili olduğunu nasıl anlayabilirim?
Parça ve etkinlik izlerinin her biri, uygulamanızda tanımlandığı şekliyle sınıf adına dayanır. Her ekran izi, sınıf adından sonra st önekini içerir. Firebase konsolunda önek kaldırılır. Daha fazla bilgi edinmek için Ekran oluşturma performans verileri hakkında bilgi (Apple ve Android uygulamaları) başlıklı makaleyi inceleyin.
Neden diğer izlere kıyasla daha az parça izi görüyorum?
Performance Monitoring, bir cihazda toplanan tüm etkinliklerde etkinlik örneklemesi yapar. Bu yaklaşım, performans metrikleri sağlamak için kullanıcı cihazlarından gereken minimum etkinlikleri toplamamıza olanak tanır.
Uygulamamın oluşturma performansıyla ilgili bir sorun olduğunda nasıl bilgilendirilirim?
Performance Monitoring, önem verdiğiniz metrikler için uyarılar ayarlamanıza olanak tanır. Oluşturulan ekran oluşturma izleri için, yavaş ve donmuş karelerin yüzdesi belirlediğiniz eşiği aştığında sizi bilgilendirecek uyarılar ayarlayabilirsiniz.
Performance Monitoring Gradle eklentisini etkinleştirdikten sonra derleme sürelerim yüksek. Bunu nasıl iyileştirebilirim?
Performance Monitoring for Android, HTTP/S ağ isteklerini izleme gibi bazı hazır özellikler sunmak için bayt kodu enstrümantasyonunu kullanır. Derleme sürecinin bir parçası olarak, uygulamanızın ağ isteği performansını ölçmede önemli olan kodu izlemek için uygulamanızın tüm sınıflarının (bağımlılıklar dahil) yinelemeli olarak işlenmesi gerekir.
Derleme süresinin artmasına neden olan bazı önemli faktörler şunlardır:
- Sınıf veya dosya sayısı
- Bu sınıfların her birinin boyutu (kod satırları)
- Makine yapılandırmanız
- İlk derleme ile sonraki derlemeler (sonraki derlemeler genellikle ilk derlemeden daha hızlıdır)
Derleme sürenizi optimize etmek için kodunuzu modüler hale getirmeyi düşünebilirsiniz.
Performance Monitoring eklentisinin v1.3.3 sürümünden itibaren, artımlı derleme işleme ve kitaplık girişlerinin önbelleğe alınması konusunda önemli iyileştirmeler yapmaya odaklandık. En son derleme süresi iyileştirmelerinden yararlanmak için eklentinin en son sürümünü (v2.0.2) kullandığınızdan emin olun.
Uzun derleme sürelerini önlemek istiyorsanız hata ayıklama derlemeleriniz için Performance Monitoring eklentisini yerel olarak devre dışı bırakabilirsiniz. Ancak bu yaklaşım, uygulamanızdaki ağ istekleriyle ilgili performans ölçümlerinin kaçırılmasına neden olabileceğinden üretim derlemeleri için önerilmez.
Performance Monitoring Gradle eklentisiyle uyumlu olmayan kitaplıklar nedeniyle derleme hataları alırsam ne yapmalıyım?
Performance Monitoring for Android, HTTP/S ağ isteklerini izleme gibi bazı hazır özellikler sunmak için bayt kodu enstrümantasyonunu kullanır. Derlemenin bir parçası olarak, süreç uygulamanızın ağ isteği performansını ölçmede kritik öneme sahip olan kodu düzenlemek için uygulamanızın tüm sınıflarında (bağımlılıklar dahil) yineleme yapılmasını gerektirir.
Performance Monitoring eklentisiyle entegrasyon yaptıktan sonra JSR/RET are not supported with
computeFrames option gibi derleme hataları veya benzer hatalar alıyorsanız bunun nedeni, Performance Monitoring Gradle eklentisiyle uyumlu olmayan bir kitaplığa da bağımlı olmanız olabilir.
Bunu aşmak için, aşağıdaki adımları izleyerek uyumsuz sınıfların/kütüphanelerin enstrümanlandırılmasını engelleyebilirsiniz:
- Performance Monitoring Gradle eklentisinin en son sürümüne güncelleyin (minimum v1.4.0).
- Android Gradle eklentinizin sürümünü v7.2.0 veya daha yeni bir sürüme güncelleyin.
- Uyumsuz sınıfların/kütüphanelerin enstrümantasyona dahil edilmesini engellemek için modülünüzün (uygulama düzeyi)
build.gradledosyasına aşağıdaki bayrağı ekleyin: Android Gradle eklentisininandroid { // ... androidComponents { onVariants(selector().all(), { instrumentation.excludes.add("example.incompatible.library") }) } }
InstrumentationAPI'sininexcludeözelliği hakkında daha fazla bilgi edinmek için Enstrümantasyon bölümüne bakın.
Lütfen uyumsuz kitaplıklar nedeniyle derleme hatalarıyla karşılaştığınızda Github sorunu oluşturun. Böylece bu kitaplıklar Performance Monitoring eklentisinde de enstrümantasyon dışında bırakılabilir.
Performance Monitoring verilerimin BigQuery'ye aktarılması beklenenden daha uzun sürüyor. Gerçek zamanlı değil mi?
Firebase Performance Monitoring için BigQuery entegrasyonunu etkinleştirdiyseniz verileriniz günün bitiminden (Pasifik Saati) 12-24 saat sonra BigQuery'ye aktarılır.
Örneğin, 19 Nisan tarihli veriler, 20 Nisan'da saat 12:00 ile gece yarısı arasında BigQuery'de mevcut olacak (tüm tarihler ve saatler Pasifik Saati'ne göredir).
Gerçek zamana yakın veri işleme ve görüntüleme
"Gerçek zamana yakın" performans verileri ne anlama geliyor?
Firebase Performance Monitoring, toplanan performans verilerini geldikçe işler. Bu sayede Firebase konsolunda veriler neredeyse gerçek zamanlı olarak gösterilir. İşlenen veriler, toplandıktan birkaç dakika sonra konsolda gösterilir. Bu nedenle "neredeyse gerçek zamanlı" ifadesi kullanılır.
Neredeyse gerçek zamanlı veri işlemeden yararlanmak için uygulamanızın gerçek zamanlı uyumlu bir SDK sürümü kullandığından emin olun.
Uygulamam için neredeyse gerçek zamanlı performans verilerini nasıl alabilirim?
Neredeyse gerçek zamanlı veri işlemeden yararlanmak için uygulamanızın gerçek zamanlı veri işleme ile uyumlu bir Performance Monitoring SDK sürümü kullandığından emin olmanız yeterlidir.
Gerçek zamanlı olarak uyumlu SDK sürümleri şunlardır:
- iOS: 7.3.0 veya sonraki sürümler
- tvOS: 8.9.0 veya sonraki sürümler
- Android: v19.0.10 veya sonraki sürümler (ya da Firebase Android BoM v26.1.0 veya sonraki sürümler)
- Web: 7.14.0 veya sonraki sürümler
Her zaman SDK'nın en son sürümünü kullanmanızı önerdiğimizi ancak yukarıda listelenen sürümlerin herhangi birinin Performance Monitoring'nın verilerinizi neredeyse gerçek zamanlı olarak işlemesini sağlayacağını unutmayın.
Performance Monitoring SDK'nın hangi sürümleri gerçek zamanlı olarak uyumlu kabul edilir?
Gerçek zamanlı veri işlemeyle uyumlu SDK sürümleri şunlardır:
- iOS: 7.3.0 veya sonraki sürümler
- tvOS: 8.9.0 veya sonraki sürümler
- Android: v19.0.10 veya sonraki sürümler (ya da Firebase Android BoM v26.1.0 veya sonraki sürümler)
- Web: 7.14.0 veya sonraki sürümler
Her zaman SDK'nın en son sürümünü kullanmanızı önerdiğimizi ancak yukarıda listelenen sürümlerin herhangi birinin Performance Monitoring'nın verilerinizi neredeyse gerçek zamanlı olarak işlemesini sağlayacağını unutmayın.
Uygulamamı gerçek zamanlı olarak uyumlu bir SDK sürümünü kullanacak şekilde güncellemezsem ne olur?
Uygulamanız gerçek zamanlı uyumlu bir SDK sürümü kullanmıyorsa uygulamanızın tüm performans verilerini Firebase konsolunda görmeye devam edersiniz. Ancak performans verilerinin gösterilmesi, toplanma zamanından yaklaşık 36 saat sonra gerçekleşir.
Gerçek zamanlı olarak uyumlu bir SDK sürümüne güncelledim ancak bazı kullanıcılarım hâlâ uygulamamın eski sürümlerini kullanıyor. Bu kullanıcıların performans verilerini Firebase konsolunda görmeye devam edecek miyim?
Evet! Bir uygulama örneğinin hangi SDK sürümünü kullandığına bakılmaksızın tüm kullanıcılarınızın performans verilerini görürsünüz.
Ancak, son verilere (yaklaşık 36 saatten daha eski) bakıyorsanız, görüntülenen veriler gerçek zamanlı uyumlu bir SDK sürümü kullanan uygulama örneklerinin kullanıcılarına aittir. Ancak son olmayan veriler, uygulamanızın tüm sürümlerine ait performans verilerini içerir.
Firebase Desteği ile İletişime Geçme
Firebase Destek Ekibi ile iletişime geçerseniz her zaman Firebase uygulama kimliğinizi ekleyin. Firebase Uygulama Kimliğinizi settings Proje ayarlarınızdaki Uygulamalarınız kartında bulabilirsiniz.