消息通知(Notification)/用戶觸達系統設計

来源:https://www.cnblogs.com/JavaEdge/archive/2023/12/14/17902401.html
-Advertisement-
Play Games

近年來,通知功能已經成為許多應用程式中突出的特性。構建一個能每天發送數百萬通知的可擴展系統絕非易事。這正是為什麼我覺得有必要記錄我在這方面踩坑之路。也叫用戶觸達系統。 完成這項任務要求對通知生態系統有深刻的理解,否則需求很容易變得模糊和不明確。 1 瞭解通知系統並確定設計範圍 通知是用於向用戶提供重 ...


近年來,通知功能已經成為許多應用程式中突出的特性。構建一個能每天發送數百萬通知的可擴展系統絕非易事。這正是為什麼我覺得有必要記錄我在這方面踩坑之路。也叫用戶觸達系統。

完成這項任務要求對通知生態系統有深刻的理解,否則需求很容易變得模糊和不明確。

1 瞭解通知系統並確定設計範圍

通知是用於向用戶提供重要信息的一種方式,如產品更新、提醒事件、優惠等。已成為應用功能清單中的重要組成部分。

通知不僅是移動推送通知。通常,根據接收者的特征

1 通知格式分類

  • 移動推送通知
  • 簡訊
  • 電子郵件
  • 網頁推送通知
  • 第三方應用通知(類似 Slack、釘釘的應用)

2 功能需求

  • 系統支持推送通知、簡訊、電子郵件和第三方應用通知。
  • 準實時系統。希望用戶儘快收到通知。然而,若系統負載過高,輕微延遲也可接受
  • 支持的設備:移動設備(iOS 和 Android)以及筆記本電腦/台式機
  • 通知可以由客戶端應用程式事件觸發,也可以在伺服器端進行計劃
  • 用戶可以選擇不再接收將來的通知
  • 大致上,我希望每天發送1000萬條推送通知、500萬封電子郵件和100萬條簡訊

3 頂層設計

首先,我們需要找出一個支持各種通知類型的高級設計:簡訊、電子郵件、iOS推送通知、Android推送通知和Slack應用通知。

然後,系統應該以以下組件結構化:

  • 不同通知類型的配置
  • 收集聯繫信息流
  • 通知發送和接收流

4 不同通知類型的高級設計與AWS

每種通知類型在高級層面上的工作原理。

4.1 簡訊

核心組件

  • Producer — 生產者構建並向【SMS Service】發送通知請求。為構建簡訊的通知請求,生產者應提供數據:帶有國家代碼的用戶電話號碼,JSON字典負載下的簡訊主題/內容。也就是公司內各業務部門
  • SMS Service,簡訊服務,用於處理自定義業務邏輯並觸發簡訊發送
  • AWS SNS或第三方簡訊服務 — 這是AWS用於發送簡訊的服務,但為增加高可用性和韌性,我添加了第三方簡訊服務選項。預設,簡訊服務將調用AWS SNS,但若異常,可切換到其他簡訊服務
  • SMS device,簡訊設備 — 接收簡訊的終端客戶端

4.2

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 引言 關於Chat2DB和文心一言是啥我就不贅述了,由於Chat2DB自帶的ai有調用次數限制,所以想著接入百度的文心AI,但是由於網上沒有找到相關的教程,此方法是本人研究了一段時間才弄出來的,順便記錄一下備忘,也希望對有同樣需求有所幫助! 一、註冊並實名認證百度智能雲賬號 百度智能雲地址:點擊前往 ...
  • 一、mycat概述 mycat是阿裡巴巴企業下的開源的,基於JAVA語言編寫的MySQL資料庫中間件,可以像使用MySQL一樣來使用Mycat,對於開發人員來說根本感覺不到mycat的存在。之前在國內使用資料庫分庫分表,讀寫分離最主流的就是使用mycat,但是截止到今日2023-12-13日,myc ...
  • HarmonyOS 實戰小項目開發(二) 日常逼逼叨 在上期實戰項目一中,已經對於練手項目的背景,後端搭建等做了一定的簡述,那麼本期將結合HarmonyOS 頁面搭建個人性格測試的移動端。如有一些錯誤,希望觀眾老爺們批評指正😃😃😃 首先放一個圖片,是整個的一個效果,至於頁面佈局配色方面的問題, ...
  • HarmonyOS 實戰小項目開發(一) 日常逼逼叨 在經過一周多的Harmonyos 開發基礎知識的學習後,自己通過對於Harmonyos基礎知識的學習之後,結合自己的一些想法,獨自完成了利用Arkts佈局的Harmonyos 項目,在此將整個過程與各位共用出來,如有一些錯誤,希望觀眾老爺們批評指 ...
  • 這裡給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 DOM小練習 彈幕 電梯導航 倒計時 隨機點名 購物放大鏡 1.彈幕 效果預覽 功能:輸入彈幕內容,按下回車顯示一條彈幕(彈幕顏色、字體隨機生成) 思路:設置按鈕抬起事件,在事件中判斷如果按下的是回車鍵則將輸入框中替換掉敏感詞的數據追加到 ...
  • 在 Chrome 擴展開發中,manifest 文件是項目的核心,其中 "content_scripts","background","permissions" 配置項又至關重要! ...
  • 即時設計平臺是一個即時搭建c端樓層的開發平臺,支持通過導入relay設計稿url完成Ui2Code,在此基礎上完成前端可視化搭建,同時支持通過ChatGPT完成一句話需求,搭建後的樓層自動同步ihub樓層市場,提供到通天塔、哥倫布等搭建平臺使用。 ...
  • 說明:任意文件上傳漏洞,很多PHP開發者也會做一些簡單的防護,但是這個防護有被繞過的可能。 原生漏洞PHP示例代碼: $file = $_FILES['file'] ?? []; //檢測文件類型 $allow_mime = ['image/jpg', 'image/jpeg', 'image/pn ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...