FCM Kısıtlama ve Kotaları

Hedefimiz, FCM kullanılarak gönderilen her mesajı her zaman iletmektir. Ancak her mesajı iletmek bazen genel kullanıcı deneyiminin kötü olmasına neden olur. Diğer durumlarda ise FCM'nin tüm gönderenler için ölçeklenebilir bir hizmet sunmasını sağlamak amacıyla sınırlamalar getirmemiz gerekir. Bu bölümde açıklanan sınır ve kota türleri, bu önemli faktörleri dengelememize yardımcı olur.

Aşağı akış mesajı sınırlaması

HTTP v1 API, aşağı akış mesajlaşma için proje başına dakika başına kotalar sunmuştur. Dakikada 600.000 mesajlık varsayılan kota, FCM geliştiricilerin% 99'undan fazlasını kapsarken sistemin kararlılığını korur ve ani artış gösteren projelerin etkisini en aza indirir.

Ani trafik artışları, kota aşıldı hatalarına neden olabilir. Kota aşımı durumunda sistem, kota bir sonraki dakikada yeniden doldurulana kadar HTTP durum kodu 429 RESOURCE_EXHAUSTED ("QUOTA_EXCEEDED") sunar. Aşırı yüklenme durumlarında da 429 yanıtları döndürülebilir. Bu nedenle, 429'ları yayınlanan önerilere göre işlemeniz önemle tavsiye edilir.

Unutmayın:

  • Aşağı akış kotası, istekleri değil iletileri ölçer.
  • İstemci hataları (HTTP durum kodu 400-499) sayılır (429'lar hariç).
  • Kotalar dakika başına belirlenir ancak bu dakikalar saatle uyumlu değildir.

İzleme kotası

Google Cloud Console'da kota, kullanım ve hataları görüntülemek için aşağıdakileri kullanabilirsiniz:

  1. Google Cloud konsoluna gidin.
  2. API'ler ve hizmetler'i seçin.
  3. Tablo listesinden Firebase Cloud Messaging API'yi seçin.
  4. KOTA VE SİSTEM SINIRLARI'nı seçin.

Kota artışı isteme

Kota artışı istemeden önce şunlardan emin olun:

  • Kullanımınız, her gün en az 5 dakika boyunca düzenli olarak kotanın% 80'i veya daha fazlası oluyor.
  • Özellikle yoğun trafik sırasında istemci hatası oranınız% 5'ten düşüktür.
  • Büyük ölçekte mesaj göndermeyle ilgili en iyi uygulamalara uyuyorsunuz.

Bu ölçütleri karşılıyorsanız +% 25'e kadar kota artışı isteği gönderebilirsiniz. FCM, isteği karşılamak için her türlü pratik çabayı gösterecektir (artış garanti edilemez).

Yaklaşan bir lansman veya geçici etkinlik nedeniyle daha fazla aşağı akış mesajlaşma kotasına ihtiyacınız varsa isteğin işlenmesi için yeterli süre tanımak amacıyla kotanızı en az 15 gün önceden isteyin. Büyük istekler (>18 milyon ileti/dakika) için en az 30 gün önceden bildirimde bulunulması gerekir. Lansmanlar ve özel etkinlik istekleri, istemci hata oranı ve en iyi uygulamalar şartlarına tabidir.

Daha fazla bilgi için FCM kotaları başlıklı makaleyi inceleyin.

Konu mesajı sınırları ve dağıtım sıklığı sınırlaması

Daha fazla ayrıntı için Konu mesajlaşma kotaları ve sınırları bölümüne bakın.

Daraltılabilir mesaj sınırlama

Daraltılabilir mesajlar bölümünde açıklandığı gibi, daraltılabilir mesajlar, içerik içermeyen ve birbirinin üzerinde daraltılacak şekilde tasarlanmış bildirimlerdir. Bir geliştiricinin aynı mesajı bir uygulamaya çok sık göndermesi durumunda, kullanıcının pilini daha az etkilemek için mesajları geciktiririz.

Örneğin, tek bir cihaza çok sayıda yeni e-posta senkronizasyonu isteği gönderirseniz cihazın daha düşük bir ortalama hızda senkronize olabilmesi için bir sonraki e-posta senkronizasyonu isteğini birkaç dakika geciktirebiliriz. Bu sınırlama, kullanıcının yaşadığı pil etkisini sınırlamak için kesinlikle gereklidir.

Kullanım alanınızda yüksek hızlı toplu gönderme kalıpları gerekiyorsa daraltılamayan mesajlar doğru seçim olabilir. Bu tür mesajlarda pil maliyetini düşürmek için mesajlardaki içeriği eklediğinizden emin olun.

Daraltılabilir mesajları, cihaz başına uygulama başına 20 mesajlık bir seriyle sınırlandırırız. 3 dakikada 1 mesaj yenilenir.

Tek bir cihaza gönderilen maksimum ileti hızı

Android'de tek bir cihaza dakikada 240, saatte 5.000 mesaj gönderebilirsiniz. Bu yüksek eşik, kullanıcıların sohbet üzerinden hızlı etkileşim kurduğu gibi kısa süreli trafik artışlarına izin vermek için belirlenmiştir. Bu sınır, gönderme mantığındaki hataların cihazın pilini yanlışlıkla tüketmesini engeller.

iOS için, hız APNs sınırlarını aştığında hata döndürürüz.