Hedefimiz, FCM kullanılarak gönderilen her mesajı her zaman iletmektir. Ancak her mesajın teslim edilmesi 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 bin 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") döndürür. 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:
- Google Cloud konsoluna gidin.
- API'ler ve hizmetler'i seçin.
- Tablo listesinden Firebase Cloud Messaging API'yi seçin.
- KOTA VE SİSTEM SINIRLARI'nı seçin.
Kota artışı isteme
Kota artışı istemeden önce şunlardan emin olun:
- Kullanımınız, günlük olarak en az 5 dakika boyunca düzenli olarak kotanın% 80'i veya daha fazlası.
- Ö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 kota artışı isteği gönderebilirsiniz. Bu istekte, kotanızın en fazla% 25 artırılmasını talep edebilirsiniz. FCM, isteğinizi karşılamak için her türlü pratik çabayı gösterecektir (artışın garanti edilemeyeceğini lütfen unutmayın).
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 edinmek için FCM kotaları başlıklı makaleyi inceleyin.
Konu mesajı sınırları ve fanout kısıtlaması
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ştirici, aynı mesajı bir uygulamaya çok sık gönderirse 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 sayıda toplu e-posta 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şimde bulunduğ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 boşaltmasını engeller.
iOS'te, hız APNs sınırlarını aştığında hata döndürülür.