طول عمر یک پیام را تنظیم کنید

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 استفاده کنید که تعداد پیام‌های ارسالی و باز شده در دستگاه‌های اپل و اندروید را به همراه داده‌های مربوط به نمایش برای برنامه‌های اندروید ثبت می‌کند.