هدف ما این است که همیشه هر پیامی را که با استفاده از FCM ارسال می شود، ارائه دهیم. با این حال، ارائه هر پیام گاهی اوقات منجر به تجربه کلی ضعیف کاربر می شود. در موارد دیگر، ما باید مرزهایی را برای اطمینان از اینکه FCM یک سرویس مقیاس پذیر برای همه فرستنده ها ارائه می دهد، فراهم کنیم. انواع محدودیت ها و سهمیه های شرح داده شده در این بخش به ما کمک می کند تا این عوامل مهم را متعادل کنیم.
کاهش فشار پیام پایین دست
HTTP v1 API سهمیههای هر پروژه و در دقیقه را برای پیامرسانی پایین دستی معرفی کرد. سهمیه پیشفرض 600 هزار پیام در دقیقه، بیش از 99 درصد از توسعهدهندگان FCM پوشش میدهد و در عین حال از پایداری سیستم محافظت میکند و تأثیر پروژههای spiky را به حداقل میرساند.
الگوهای ترافیک تیره می تواند منجر به خطاهای بیش از حد سهمیه شود. در یک سناریوی بیش از سهمیه، سیستم کد وضعیت HTTP 429 (QUOTA_EXCEEDED) را تا زمانی که سهمیه در دقیقه بعد دوباره پر شود، ارائه میکند. 429 پاسخ نیز ممکن است در موقعیتهای اضافه بار برگردانده شوند، بنابراین شما قویاً تشویق میشوید که 429 را طبق توصیههای منتشر شده مدیریت کنید.
توجه داشته باشید که:
- سهمیه پایین دستی پیام ها را اندازه گیری می کند نه درخواست ها.
- خطاهای مشتری (کد وضعیت HTTP 400-499) شمارش می شود (به استثنای 429s).
- سهمیه ها در هر دقیقه است، اما این دقیقه ها با ساعت هماهنگ نیستند.
سهمیه نظارت
میتوانید سهمیه، استفاده و خطاها را در Google Cloud Console مشاهده کنید:
- به کنسول Google Cloud بروید
- APIs & services را انتخاب کنید
- از لیست جدول، Firebase Cloud Messaging API را انتخاب کنید
- QUOTA & SYSTEM LIMITS را انتخاب کنید.
توجه: این نمودارها دقیقاً با دقیقه های سهمیه تراز زمانی نیستند، به این معنی که ممکن است زمانی که به نظر می رسد ترافیک زیر سهمیه است، 429 ثانیه ارائه شود.
درخواست افزایش سهمیه
قبل از درخواست افزایش سهمیه، اطمینان حاصل کنید که:
- استفاده شما به طور منظم ≥ 80% سهمیه حداقل برای 5 دقیقه متوالی در روز است.
- نسبت خطای مشتری کمتر از 5٪ است، به خصوص در زمان اوج ترافیک.
- شما به بهترین شیوه ها برای ارسال پیام در مقیاس پایبند هستید.
اگر این معیارها را داشته باشید، می توانید درخواست افزایش سهمیه تا 25% را ارسال کنید و FCM تمام تلاش عملی خود را برای انجام این درخواست انجام خواهد داد (هیچ افزایشی تضمین نمی شود).
اگر به دلیل راهاندازی قریبالوقوع یا رویداد موقتی به سهمیه پیامرسانی پاییندست بیشتری نیاز دارید، حداقل 15 روز قبل سهمیه خود را درخواست کنید تا زمان کافی برای رسیدگی به درخواست در نظر گرفته شود. برای درخواست های بزرگ (بیش از 18 میلیون پیام در دقیقه)، حداقل 30 روز اطلاع رسانی لازم است. راهاندازیها و درخواستهای رویداد ویژه همچنان مشمول نسبت خطای مشتری و الزامات بهترین شیوهها هستند.
همچنین به سوالات متداول در مورد سهمیه های FCM مراجعه کنید.
محدودیت پیام موضوع
نرخ اضافه یا حذف اشتراک موضوع به 3000 QPS در هر پروژه محدود شده است.
برای نرخهای ارسال پیام، به Fanout Throttling مراجعه کنید.
دریچه گاز فان اوت
پیام Fanout فرآیند ارسال پیام به چندین دستگاه است، مانند زمانی که موضوعات و گروهها را هدف قرار میدهید، یا زمانی که از سازنده Notifications برای هدف قرار دادن مخاطبان یا بخشهای کاربر استفاده میکنید.
پیام fanout آنی نیست و بنابراین گاهی اوقات شما چندین fanout به طور همزمان در حال انجام است. تعداد پیامهای همزمان در هر پروژه را به 1000 محدود میکنیم. پس از آن، ممکن است درخواستهای fanout اضافی را رد کنیم یا fanout درخواستها را تا زمانی که برخی از Fanoutهای در حال انجام کامل تکمیل شوند به تعویق بیاندازیم.
نرخ واقعی fanout قابل دستیابی تحت تأثیر تعداد پروژه هایی است که همزمان درخواست fanout می کنند. نرخ fanout 10000 QPS برای یک پروژه غیر معمول نیست، اما این عدد تضمینی نیست و نتیجه کل بار روی سیستم است. توجه به این نکته مهم است که ظرفیت fanout موجود بین پروژهها تقسیم میشود و نه بین درخواستهای fanout. بنابراین، اگر پروژه شما دارای دو fanout در حال انجام باشد، هر fanout فقط نیمی از نرخ fanout موجود را خواهد دید. روش توصیه شده برای به حداکثر رساندن سرعت فنآوت این است که هر بار فقط یک فنآوت فعال در حال انجام باشد.
خفه کردن پیام تاشو
همانطور که در پیامهای تاشو توضیح داده شد، پیامهای جمعشونده اعلانهایی بدون محتوا هستند که برای جمع شدن روی یکدیگر طراحی شدهاند. در صورتی که یک برنامهنویس به طور مکرر همان پیام را برای یک برنامه تکرار کند، پیامها را به تأخیر میاندازیم تا تأثیر آن بر باتری کاربر کاهش یابد.
برای مثال، اگر تعداد زیادی درخواست همگامسازی ایمیل جدید را به یک دستگاه ارسال کنید، ممکن است درخواست همگامسازی ایمیل بعدی را چند دقیقه به تأخیر بیندازیم تا دستگاه بتواند با سرعت متوسط پایینتری همگامسازی شود. این دریچه گاز به شدت برای محدود کردن تاثیر باتری تجربه شده توسط کاربر انجام می شود.
اگر مورد استفاده شما به الگوهای ارسال پشت سر هم زیاد نیاز دارد، پیام های غیرقابل جمع شدن ممکن است انتخاب مناسبی باشند. برای چنین پیامهایی، حتماً محتوا را در چنین پیامهایی قرار دهید تا هزینه باتری کاهش یابد.
ما پیامهای جمعشونده را به 20 پیام در هر برنامه در هر دستگاه محدود میکنیم و هر 3 دقیقه یک پیام را دوباره پر میکنیم.
حداکثر نرخ پیام به یک دستگاه
برای اندروید میتوانید تا ۲۴۰ پیام در دقیقه و ۵۰۰۰ پیام در ساعت به یک دستگاه ارسال کنید. این آستانه بالا به این منظور است که امکان انبوه ترافیک کوتاه مدت را فراهم می کند، مانند زمانی که کاربران به سرعت از طریق چت در حال تعامل هستند. این محدودیت از تخلیه ناخواسته باتری روی دستگاه خطا در ارسال منطق جلوگیری می کند.
برای iOS، زمانی که نرخ از محدودیتهای APN فراتر رود، خطا را برمیگردانیم.