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 推播通知服務 (APNs)
    • 網頁應用程式的網路推播通訊協定

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

生命週期流程

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