【京東咚咚架構演進】-- 好文收藏

来源:http://www.cnblogs.com/Meng-NET/archive/2017/08/02/7272108.html
-Advertisement-
Play Games

架構好文學習,攢~~ 京東咚咚架構演進 -- By 【瞬息之間】 名詞解釋: Apache MINA: 百度百科 HAProxy: 百度百科 1.0 架構筆記: 優點:模型結構簡單 理解起來簡單;開發起來簡單;部署起來也簡單。 缺點:效率和擴展 這個模型實際上是一個高功耗低效能的模型,不活躍的連接在 ...


架構好文學習,攢~~

京東咚咚架構演進 -- By 【瞬息之間】

名詞解釋:

  Apache MINA: 百度百科

  HAProxy: 百度百科

1.0 架構筆記:

  優點:模型結構簡單---理解起來簡單;開發起來簡單;部署起來也簡單。

  缺點:效率和擴展---這個模型實際上是一個高功耗低效能的模型,不活躍的連接在那做高頻率的無意義輪詢,高頻有多高呢,基本在 100 ms 以內,

     你不能讓輪詢太慢,比如超過 2 秒輪一次,人就會在聊天過程中感受到明顯的會話延遲。 隨著線上人數增加,輪詢的耗時也線性增長,

     因此這個模型導致了擴展能力和承載能力都不好,一定會隨著線上人數的增長碰到性能瓶頸。

2.0 架構筆記:

  改進點:業務功能體驗的提升上---針對無法及時提供服務的顧客,可以排隊或者留言。 針對純文字溝通,提供了文件和圖片等更豐富的表達方式。

      另外支持了客服轉接和快捷回覆等方式來提升客服的接待效率。

3.0 架構筆記:

  改進點:業務劃分服務,且服務進行分層---服務化的第一個問題如何把一個大的應用系統切分成子服務系統。

      按業務重要性級別劃分了 0、1、2 三個級別不同的子業務服務系統。 另外就是獨立了一組接入服務,針對不同渠道和通信方式的接入端。

      服務架構&分層---a.UI接入層 --- 客服用(web/app..)系統,員工用(web/app/pc...)

                b.負載均衡層 --- TCP長連接,HTTP短連接

                c.路由服務層 --- 路由 Tracker

                d.業務服務層 --- 業務子系統及API服務

                e.基礎服務層 --- 基礎框架服務(安全/風控/資源分配...)

                f.資源服務層 --- DB/Cache/NoSQL/MQ....

      消息投遞模型---不再是輪詢了,而是讓終端每次建立連接後註冊接入點位置,消息投遞前定位連接所在接入點位置再推送過去。

             這樣投遞效率就是恆定的了,而且很容易擴展,線上人數越多則連接數越多,只需要擴展接入點即可。 

             使用了 MongoDB 來單獨存儲量最大的聊天記錄。 

4.0 架構筆記:

  拍拍網消息缺陷:a.複製工程,定製業務開發,多套源碼維護成本高

          b.獨立部署,至少雙機房主備外加一個灰度集群,資源浪費大

  系統持續演進:面向平臺---始考慮面向平臺去架構,在統一平臺上跑多套業務,統一源碼,統一部署,統一維護。 把業務服務繼續拆分,

         剝離出最基礎的 IM 服務,IM 通用服務,客服通用服務,而針對不同的業務特殊需求做最小化的定製服務開發。

         部署方式則以平臺形式部署,不同的業務方的服務跑在同一個平臺上,但數據互相隔離。

         細粒度服務開發---更細粒度的服務意味著每個服務的開發更簡單,代碼量更小,依賴更少,隔離穩定性更高。

  架構VS業務: 技術架構沒有絕對的好與不好, 技術架構總是要放在彼時的背景下來看,要考慮業務的時效價值、團隊的規模和能力、

           環境基礎設施等等方面。 架構演進的生命周期適時匹配好業務的生命周期,才可能發揮最好的效果。

 

 

 

                                         蒙

                                    2017-08-02 09:20 周三

 


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

-Advertisement-
Play Games
更多相關文章
  • 對於剛學過框架的同學可能知道,mybatis有兩種主要的配置文件: SqlMapConfig.xml(mybatis全局配置文件,名稱不固定,用來配置運行環境(數據源、事務) XXXmapper.xml 主要用來配置sql語句 我以前做過一個項目,大概的層次結構如下: 從這個UML圖中可以看出這個項 ...
  • 如果要進行整除,使用 // 運算符,它將返回商的整數部分 >>> 4 // 3.01.0 Python中單行註釋以 # 開頭,例如: 多行註釋用三個單引號 ''' 或者三個雙引號 """ 將註釋括起來,例如: '''這是多行註釋,用三個單引號這是多行註釋,用三個單引號 這是多行註釋,用三個單引號'' ...
  • 工作中需要在c++代碼中嵌入ruby c api,然而在vs工程中編譯失敗,所以現在通過手動從源代碼編譯ruby尋找原因(之前使用rubyinstaller安裝)。 先從官網下載ruby 2.4.1 版本,https://www.ruby-lang.org/en/downloads/ 從安裝指導可以 ...
  • 1.我們需要建立一個Django的Project: django-admin.py startproject ProjectName 2.需要對這個Project 進行調整: 首次執行migrate是為了確保Django中資料庫與項目的當前狀態匹配 python manage.py migrate ...
  • 背景 環境需要設置代理才能夠訪問外部網路,如果只是運行java程式來訪問網路,我們可以通過java jar test.jar DproxyHost=proxy_ip DproxyPort=proxy_port,但如果是java的maven項目中,單元測試需要訪問網路,只執行mvn test則會導致單 ...
  • 公司的項目底層,是使用的TCP,因為可靠,自動斷線重連,在底層都實現了,但是我記得TCP也會有掉包的問題,所以這文章就誕生了——關於TCP掉包的問題,TCP是基於不可靠的網路實現可靠的傳輸,肯定也會存在掉包的情況。 如果通信中發現缺少數據或者丟包,那麼,最大的可能在於程式發送的過程或者接收的過程出現 ...
  • 這一章主要介紹什麼是[BX]以及loop(迴圈)指令怎麼使用,loop和[BX]又怎麼樣相結合,段首碼又是什麼鬼,以及如何使用段首碼。 1、[BX]的概念 [BX]和[0]類似,[0]表示記憶體單元的偏移地址是0。要完整描述一個記憶體單元,需要兩種信息:記憶體單元的地址,記憶體單元的長度(類型)。[BX]同 ...
  • 不久前參與開發了一個基於dubbo分散式框架的底層賬單系統,並實現了其中的一部分業務介面,目前需對這些介面進行壓測,以評估生產環境所能承受的最大吞吐量。筆者以其中一個查詢介面為例來回顧此次壓測的整體流程。 壓測準備: 1.調用查詢介面的測試jar包,作為dubbo-consumer,依賴了查詢服務的 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...