FCM 架構總覽

FCM 需要使用以下一組元件來建構、傳輸及接收訊息:

  1. 撰寫或建構訊息要求的工具。通知編寫工具提供以 GUI 為基礎的選項,可用於建立通知要求。如要全面自動化並支援所有訊息類型,您必須在支援 Firebase Admin SDK 或 FCM 伺服器通訊協定的可信任的伺服器環境中建構訊息要求。這個環境可以是 Cloud Functions for Firebase、App Engine 或您自己的應用程式伺服器。

    本頁所述三個架構層的圖表。

  2. FCM 後端 (和其他函式) 會接收訊息要求、透過主題執行訊息擴散,並產生訊息 ID 等訊息中繼資料。

  3. 平台層級傳輸層,可將訊息轉送至指定裝置、處理訊息傳送作業,並視情況套用平台專屬的設定。這個傳輸層包括:

    • 搭載 Google Play 服務的 Android 裝置適用的 Android 傳輸層 (ATL)
    • Apple 裝置適用的 Apple 推播通知服務 (APN)
    • 網頁應用程式的網路推播通訊協定

  4. 使用者裝置上的 FCM SDK,會顯示通知,或根據應用程式的前景/背景狀態以及任何相關的應用程式邏輯處理訊息。

生命週期流程

  • 註冊裝置以接收來自 FCM 的訊息。用戶端應用程式的執行個體會註冊接收訊息,並取得可唯一識別應用程式執行個體的註冊權杖。
  • 傳送及接收下游訊息
    • 傳送訊息。應用程式伺服器會將訊息傳送至用戶端應用程式:
      1. 訊息會在通知編寫工具或信任環境中編寫,並將訊息要求傳送至 FCM 後端。
      2. FCM 後端會接收訊息要求,產生訊息 ID 和其他中繼資料,然後傳送至平台專屬的傳輸層。
      3. 裝置連上網路時,訊息會透過平台專屬的傳輸層傳送至裝置。
      4. 在裝置上,用戶端應用程式會收到訊息或通知。