跨平臺C++通用分散式伺服器框架

来源:http://www.cnblogs.com/irons/archive/2016/03/18/5292302.html
-Advertisement-
Play Games

分散式伺服器框架 框架簡介 此框架由三種伺服器組成: n個 :負責處理客戶端的網路鏈接,並轉發客戶端和邏輯伺服器之間的消息。 n個 :負責處理(由鏈接伺服器轉發過來的)客戶端的網路消息 1個 :負責處理全局邏輯 其實還額外需要一個神器: "etcd" ,作為伺服器框架中的 感知 的新增和失效 無論拓


分散式伺服器框架

框架簡介

  • 此框架由三種伺服器組成:
    • n個連接伺服器:負責處理客戶端的網路鏈接,並轉發客戶端和邏輯伺服器之間的消息。
    • n個邏輯伺服器:負責處理(由鏈接伺服器轉發過來的)客戶端的網路消息
    • 1個全局伺服器:負責處理全局邏輯
    • 其實還額外需要一個神器:etcd,作為伺服器框架中的邏輯伺服器感知鏈接伺服器的新增和失效
    • 無論拓撲圖請參考架構圖:
  • 框架內置組件:
    • 多連接ssdb客戶端
    • redis/ssdb代理伺服器
    • 僅支持C++語言的RPC(支持protobuf類型消息,適合伺服器之間業務開發,並支持非同步回調)

既定規則(建議)

  • 客戶端擁有最多兩個邏輯伺服器:分別是Primay和Slave
  • 當客戶端鏈接某鏈接伺服器會(自動)分配一個Primary類型的邏輯伺服器(且不會、也不能重設)
  • 客戶端的消息優先(轉到到)Slave處理
  • 邏輯伺服器可自由設置客戶端的當前Slave
  • 當然,客戶端的Primay和Slave可以為同一個邏輯伺服器
  • 實際項目中,您可以藉助第三方負載均衡伺服器來分配鏈接伺服器的地址給客戶端.
  • 內置有ssdb客戶端和ssdb代理伺服器,如果你的應用需要資料庫,不妨一試。

使用方式

  • 開發應用時,只需要關註客戶端邏輯伺服器之間的消息設定,不需要考慮鏈接伺服器,且沒有任何(需要引入的)預設消息。
  • 開發應用時,只需要分別實現邏輯伺服器中的initLogicServerExt函數 和 (可選)全局伺服器中的initCenterServerExt函數 (通常進行消息handle註冊即可)。
  • 作為示例

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

-Advertisement-
Play Games
更多相關文章
  • 剛開始學習python變成, 這勉強算是第一個博客吧, 主要記錄了一下 字元串 中的方法, 不太準確,或者是錯誤的地方, 請大家指點 str1 = "GooGle" str2 = "baidu" #print("Google的類型是 %s \n" % type(str1)) #Google的類型是 ...
  • 今天看js高級編程form表單這一章,看著書上的例子敲代碼的時候出現了一點問題,什麼問題先不說,先看這段代碼? 代碼就是上面這個樣子的,很簡單的一個表單裡面有一組radio標簽,要實現的效果也就是通過表單拿到這一組radio標簽,但是我按照上面的寫法打出來之後控制台卻一直報錯,錯誤信息如下: 意思就
  • 隨著公司的規模及項目的增多,會有一種透明傳輸的需求,而透明傳輸的這一層就用來做許可權控制,灰度發佈,流量統計。 實現透傳需要註意的幾點: 1.Spring MVC實現url通配,後端服務的url各式各樣,並不能按照你所設想的長度,so,通配符能解決這個問題。 2.body流解析,POST/PUT/PA
  • 在java中,集合這一數據結構應用廣泛,應用最多的莫過於List介面下麵的ArrayList和LinkedList; 我們先說List, 下麵我們看一看ArrayList,ArrayList是基於數組的方式來實現數據的增加、刪除、修改、搜索的。 ArrayList內部維護者兩個變數: 我們再看一看A
  • 折騰了半天時間,終於知道怎麼使用go get 命令了。 具體的解決辦法: 1. 開啟socks5代理(比如shadowsocks) 2. 安裝並啟動polipo mac下: 參考自 "這裡" 1. brew install polipo 2. vi /usr/local/opt/polipo/hom
  • Atitit.atiDataStoreService v2 新特性 1.1. V1 基礎實現1 1.2. V2 增加了對 $uuid $cur_uid參數的支持1 1.3. 增加了fld fun的支持1 2. fld fun1 2.1. Invoke 簡化版全局函數txt2html1 2.2. at
  • Atitit.cateService分類管理新特性與設計文檔說明v1 1. V2 新特性規劃1 2. 分類管理1 3. 分類增加與修改維護2 4. Js控制項分類數據綁定2 增加prj屬性 增加module 屬性 http://localhost/good!getGoodTypeInfo.ct 作者:
  • https://www.aliyun.com/ https://bce.baidu.com/index.html http://www.qcloud.com/ https://cloud.360.cn/ https://www.ucloud.cn/ https://mos.meituan.com/
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...