FCM معمولاً پیامها را بلافاصله پس از ارسال تحویل میدهد. با این حال، این ممکن است همیشه امکانپذیر نباشد. به عنوان مثال، ممکن است دستگاه در دسترس نباشد یا FCM عمداً پیامها را به تأخیر بیندازد تا از مصرف بیش از حد منابع توسط یک برنامه و تأثیر منفی بر عمر باتری جلوگیری کند.
در این موارد، FCM پیام را ذخیره کرده و در اسرع وقت آن را ارسال میکند. اگرچه این در بیشتر موارد خوب است، اما برخی برنامهها وجود دارند که نیاز دارند اعلانها بدون تأخیر ارسال شوند. به عنوان مثال، اعلانی برای تماس دریافتی یا دعوت به یک رویداد.
در اندروید و وب، میتوانید حداکثر طول عمر یک پیام را مشخص کنید. مقدار باید مدت زمانی از 0 تا 2,419,200 ثانیه (28 روز) باشد و مربوط به حداکثر مدت زمانی است که FCM پیام را ذخیره و سعی در ارسال آن دارد. به طور پیشفرض، درخواستهایی که حاوی این فیلد نیستند، حداکثر چهار هفته طول میکشند.
در iOS، میتوانید هدر apns-expiration را در شیء ApnsConfig تنظیم کنید. برای جزئیات بیشتر، به مستندات اپل در مورد ارسال درخواستهای اعلان به APNها مراجعه کنید.
در اینجا به برخی از کاربردهای احتمالی این ویژگی اشاره میکنیم:
- تماسهای ورودی چت تصویری
- رویدادهای دعوتنامه در حال انقضا
- رویدادهای تقویم
Another advantage of specifying the lifespan of a message is that FCM doesn't apply collapsible message throttling to messages with a time to live value of 0 seconds. Keep in mind that a ttl value of 0 means messages that can't be delivered immediately are discarded. However, because such messages are never stored, this provides the best latency for sending notification messages.
در اینجا مثالی از درخواستی که شامل ttl است، آورده شده است:
{
"message":{
"token":"bk3RNwTe3H0:CI2k_HHwgIpoDKCIZvvDMExUdFQ3P1...",
"data":{
"Nick" : "Mario",
"body" : "great match!",
"Room" : "PortugalVSDenmark"
},
"apns":{
"headers":{
"apns-expiration":"1604750400"
}
},
"android":{
"ttl":"4500s"
},
"webpush":{
"headers":{
"TTL":"4500"
}
}
}
}
طول عمر یک پیام
وقتی یک سرور برنامه پیامی را به FCM ارسال میکند و یک شناسه پیام دریافت میکند، به این معنی نیست که پیام قبلاً به دستگاه تحویل داده شده است. در عوض، به این معنی است که برای تحویل پذیرفته شده است. زمان تحویل پیام به عوامل زیادی بستگی دارد.
اگر دستگاه متصل باشد اما در حالت Doze باشد، یک پیام با اولویت پایین توسط FCM ذخیره میشود تا زمانی که دستگاه از Doze خارج شود. اگر collapse_key تنظیم شده باشد و یک پیام موجود با همان کلید فروپاشی و توکن ثبت نام منتظر تحویل باشد، پیام قدیمی حذف شده و سپس پیام جدید جای آن را میگیرد. با این حال، اگر کلید فروپاشی تنظیم نشده باشد، هر دو پیام جدید و قدیمی برای تحویل در آینده ذخیره میشوند.
اگر دستگاه به FCM متصل نباشد، پیام تا زمان برقراری اتصال ذخیره میشود. وقتی اتصال برقرار شد، FCM تمام پیامهای در انتظار را به دستگاه ارسال میکند. اگر دستگاه دیگر هرگز متصل نشود، پیام در نهایت منقضی میشود و از حافظه FCM حذف میشود. مهلت پیشفرض چهار هفته است، مگر اینکه پرچم ttl تنظیم شده باشد. اگر برنامه هنگام تلاش FCM برای ارسال پیام به دستگاه، حذف شده باشد، FCM آن پیام را فوراً حذف میکند و توکن ثبت نام را نامعتبر میکند. تلاشهای بعدی برای ارسال پیام به آن دستگاه منجر به خطای NotRegistered میشود.
برای دستگاههای اندروید، اگر دستگاه بیش از یک ماه به FCM متصل نشده باشد، FCM همچنان پیام را میپذیرد اما بلافاصله آن را حذف میکند. اگر دستگاه ظرف چهار هفته از آخرین پیام دادهای که برای آن ارسال کردهاید متصل شود، برنامه کلاینت شما فراخوانی onDeletedMessages() را دریافت میکند.
برای کسب اطلاعات بیشتر در مورد تحویل پیامها در پلتفرمهای اندروید یا اپل، میتوانید از داشبورد گزارشدهی FCM استفاده کنید که تعداد پیامهای ارسالی و باز شده در دستگاههای اپل و اندروید را به همراه دادههای مربوط به نمایش برای برنامههای اندروید ثبت میکند.