ויסות נתונים (throttle) ומכסות ב-FCM

המטרה שלנו היא תמיד למסור כל הודעה שנשלחת באמצעות FCM. עם זאת, מסירת כל הודעה לפעמים גורמת לחוויית משתמש כללית גרועה. במקרים אחרים, אנחנו צריכים לספק גבולות כדי להבטיח ש-FCM יספק שירות ניתן להרחבה לכל השולחים. סוגי המגבלות והמכסות שמתוארים בקטע הזה עוזרים לנו לאזן בין הגורמים החשובים האלה.

הגבלת קצב העברת הודעות (throttling) בהעברה במורד הזרם

ב-HTTP v1 API הוספנו מכסות לכל פרויקט ולכל דקה לשליחת הודעות במורד הזרם. מכסת ברירת המחדל של 600,000 הודעות לדקה מכסה יותר מ-99% מהמפתחים, תוך שמירה על יציבות המערכת ומזעור ההשפעה של פרויקטים עם עליות חדות.FCM

דפוסי תנועה עם עליות חדות עלולים לגרום לשגיאות שקשורות לחריגה מהמכסה. במקרה של חריגה מהמכסה, המערכת מציגה את קוד הסטטוס 429 RESOURCE_EXHAUSTED‏ HTTP (QUOTA_EXCEEDED) עד שהמכסה מתמלאת מחדש בדקה הבאה. יכול להיות שיוחזרו גם תגובות 429 במצבי עומס יתר, ולכן מומלץ מאוד לטפל בתגובות 429 בהתאם להמלצות שפורסמו.

חשוב לזכור:

  • המכסה במורד הזרם מתייחס להודעות ולא לבקשות.
  • שגיאות לקוח (קוד סטטוס של HTTP‏ 400-499) נספרות (לא כולל שגיאות 429).
  • המכסות הן לדקה, אבל הדקות האלה לא תואמות לשעון.

מכסת ניטור

במסוף Google Cloud אפשר לראות את המכסה, השימוש והשגיאות:

  1. עוברים אל מסוף Google Cloud.

  2. בוחרים באפשרות APIs & Services (ממשקי API ושירותים).

  3. ברשימת הטבלאות, בוחרים באפשרות Firebase Cloud Messaging API.

  4. בוחרים באפשרות QUOTA & SYSTEM LIMITS (מכסות ומגבלות מערכת).

שליחת בקשה להגדלת המכסה

לפני שמבקשים להגדיל את המכסה, חשוב לוודא את הדברים הבאים:

  • השימוש שלכם הוא באופן קבוע ≥ 80% מהמכסה למשך 5 דקות רצופות לפחות בכל יום.
  • שיעור השגיאות בצד הלקוח הוא פחות מ-5%, במיוחד בזמן שיא התנועה.
  • אתם פועלים לפי השיטות המומלצות לשליחת הודעות בהיקף גדול.

אם אתם עומדים בקריטריונים האלה, אתם יכולים להגיש בקשה להגדלת המכסה בשיעור של עד 25% במסוף Google Cloud באמצעות:

  1. עוברים אל QUOTA & SYSTEM LIMITS.
  2. בטבלה, בוחרים את השורה Send requests per minute.
  3. לוחצים על הלחצן עריכה.
  4. פועלים לפי ההוראות כדי לשלוח את הבקשה.

FCM נשתדל מאוד למלא את הבקשה (לא ניתן להבטיח הגדלה).

אם אתם צריכים מכסת הודעות גדולה יותר בגלל השקה קרובה או אירוע זמני, אתם צריכים לשלוח בקשה להגדלת המכסה דרך התמיכה של Firebase. אתם צריכים לשלוח את הבקשה לפחות 15 ימים מראש כדי שיהיה לנו מספיק זמן לטפל בה. אם אתם שולחים בקשה גדולה (יותר מ-18 מיליון הודעות בדקה), אתם צריכים לשלוח אותה לפחות 30 ימים מראש. אנחנו יכולים לאשר רק 2 אירועים של מכסה זמנית בשנה. משך הזמן הכולל של מכסה זמנית במהלך השנה לא יכול לעלות על 30 ימים. בקשות להשקות ולאירועים מיוחדים עדיין כפופות לדרישות של יחס שגיאות הלקוח ולשיטות המומלצות.

מידע נוסף זמין במאמר בנושא מכסות של FCM.

מגבלות על הודעות בנושאים וויסות של העברת הודעות

פרטים נוספים זמינים במאמר בנושא מכסות ומגבלות של הודעות בנושאים.

הגבלת קצב השליחה של הודעות שניתנות לכיווץ

כפי שמתואר במאמר בנושא הודעות שניתן לכווץ, הודעות שניתן לכווץ הן התראות ללא תוכן שנועדו להתקפל אחת על השנייה. אם מפתח חוזר על אותה הודעה באפליקציה בתדירות גבוהה מדי, אנחנו מעכבים את ההודעות כדי לצמצם את ההשפעה על הסוללה של המשתמש.

לדוגמה, אם אתם שולחים מספר גדול של בקשות חדשות לסנכרון אימייל למכשיר יחיד, יכול להיות שנשהה את הבקשה הבאה לסנכרון אימייל למשך כמה דקות, כדי שהמכשיר יוכל לבצע סנכרון בקצב ממוצע נמוך יותר. ההגבלה הזו מתבצעת אך ורק כדי לצמצם את ההשפעה על הסוללה שהמשתמש חווה.

אם תרחיש השימוש שלכם דורש דפוסי שליחה של פרצי תנועה, יכול להיות שהודעות לא מצטמצמות הן הבחירה הנכונה. בהודעות כאלה, חשוב לכלול את התוכן כדי להפחית את עלות הסוללה.

אנחנו מגבילים את מספר ההודעות שניתן לכווץ ל-20 הודעות לכל אפליקציה לכל מכשיר, עם מילוי של הודעה אחת כל 3 דקות.

קצב ההודעות המקסימלי למכשיר יחיד

ב-Android, אפשר לשלוח עד 240 הודעות בדקה ו-5,000 הודעות בשעה למכשיר יחיד. הסף הגבוה הזה נועד לאפשר פרצי תנועה לטווח קצר, למשל כשמשתמשים יוצרים אינטראקציה מהירה בצ'אט. המגבלה הזו מונעת שגיאות בלוגיקת השליחה שעלולות לגרום לניקוז הסוללה במכשיר.

ב-iOS, אנחנו מחזירים שגיאה כשהקצב חורג מהמגבלות של APNs.