TYPESDK手游聚合SDK服務端設計思路與架構之一:應用場景分析

来源:http://www.cnblogs.com/laohaizei/archive/2016/12/19/6196901.html
-Advertisement-
Play Games

TYPESDK 服務端設計思路與架構之一:應用場景分析 作為一個渠道SDK統一接入框架,TYPESDK從一開始,所面對的需求場景就是多款游戲,通過一個統一的SDK服務端,能夠同時接入幾十個甚至幾百個各種渠道的SDK。而且這些渠道介面的具體接入欄位和接入邏輯,每個月以至每周,都可能發生或大或小的變動。 ...


TYPESDK 服務端設計思路與架構之一:應用場景分析

         作為一個渠道SDK統一接入框架,TYPESDK從一開始,所面對的需求場景就是多款游戲,通過一個統一的SDK服務端,能夠同時接入幾十個甚至幾百個各種渠道的SDK。而且這些渠道介面的具體接入欄位和接入邏輯,每個月以至每周,都可能發生或大或小的變動。在這樣一個複雜的應用場景下,我們應該如何設計一個足夠強大而又足夠靈活的SDK服務端呢?

         首先我們需要釐清,在整個應用場景中,TYPESDK所處的位置,以及它所需要實現的核心功能。

        

圖1

如圖1所示,TYPESDK服務端最關心的介面,是游戲服務端與TYPESDK服務端之間的通信介面,以及渠道服務端與TYPESDK服務端之間的通信介面。以登錄流程為例,就是游戲服務端向TYPESDK服務端發起的驗證用戶請求和渠道服務端向TYPESDK服務端返回的驗證結果;以支付流程為例,就是渠道服務端向TYPESDK服務端發起的支付完成回調和TYPESDK服務端向游戲服務端發起的發貨請求。

         下麵我們分別就這兩個主要流程進行分析:

        

圖2

流程說明

  1. 用戶點擊登錄按鈕時,游戲客戶端調用TypeSDK登錄介面,詳細調用方式及參數說明請參考客戶端介面文檔
  2. TypeSDK客戶端調用渠道客戶端SDK的API登錄
  3. 渠道客戶端SDK自我機制請求渠道服務端
  4. 渠道客戶端SDK獲取服務端返回的驗證用參數
  5. TypeSDK客戶端獲取渠道客戶端SDK獲得的參數並包裝
  6. 游戲客戶端獲取包裝後的參數
  7. 游戲客戶端將包裝後參數用自身機制傳輸給游戲服務端
  8. 游戲服務端訪問TypeSDK服務端的用戶會話驗證介面。將流程6中獲得的參數傳送給TypeSDK服務端。
  9. TypeSDK服務端訪問渠道服務端的用戶驗證介面,進行登錄驗證
  10. 渠道返回驗證結果
  11. TypeSDK服務端對渠道返回的驗證結果進行包裝,返回給游戲服務端游戲服務端根據渠道驗證結果,通知游戲客戶端本次登錄是否成功。

 

從以上的流程中可以分析出,在登錄流程中,TYPESDK服務端所需要完成的工作就是完成一個包裝的動作。將游戲服務端提供的標準化的參數,根據渠道的要求進行分別包裝,讓數據符合渠道服務端的需求,隨後提交給渠道服務端。然後再把各種渠道返回的千奇百怪的驗證結果做出區分解析,再通知游戲服務端,以供游戲邏輯使用。

 

 

圖3

流程說明

  1. 充值訂單到帳後,渠道服務端非同步通知TYPESDK服務端
  2. TYPE服務端通知游戲服務端發貨
  3. 游戲服務端收到發貨請求後先保存該請求,立刻返回TYPESDK服務端,表示已收到發貨請求。
  4. TYPESDK返回渠道服務端
  5. 游戲服務端非同步處理髮貨邏輯。並通知游戲客戶端

 

再看充值到帳流程,在這個簡化版的充值到帳流程中,我們可以看到,TYPESDK服務端所完成的工作也是一個簡單的包裝動作,將各種不同的渠道回調請求包裝成標準的數據格式,通知給游戲服務端,供游戲處理髮貨。

根據以上分析,我們就理清了TYPESDK服務端在整個流程中的位置和主要工作。在接下來的文章中,我們再具體的分析,怎樣的設計,才能讓它更好的適應靈活多變的應用場景,應付主要風險。以及如何將各大渠道的服務端SDK,接入我們這個統一的框架中。


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

-Advertisement-
Play Games
更多相關文章
  • 使用阿裡大於API發送簡訊,但阿裡沒有提供NetCore 的API,自己看了下源碼重寫了發簡訊這個部分 public class MessageSender { private readonly string _appKey; private readonly string _appSecret; ...
  • 什麼是負載均衡 負載均衡(Load Balance)是分散式系統架構設計中必須考慮的因素之一,它通常是指,將請求/數據【均勻】分攤到多個操作單元上執行,負載均衡的關鍵在於【均勻】。 常見的負載均衡方案 常見互聯網分散式架構如上,分為客戶端層、反向代理nginx層、站點層、服務層、數據層。可以看到,每 ...
  • 回到目錄 什麼是LindAspects 之前寫了關於Aspects的文章《Lind.DDD.Aspects通過Plugins實現方法的動態攔截~Lind里的AOP》,今天主要在設計思想上進行刨析一下,對緩存攔截器一直沒有實現,所以文章了也一直沒有發出來,讓大家等這麼久實在不好意思。LindAspec ...
  • 一、概述 橋接模式:將兩個原本不相關的類結合在一起,然後利用兩個類中的方法和屬性,輸出一份新的結果。 二、案例 1、模擬毛筆(轉) 需求:現在需要準備三種粗細(大中小),並且有五種顏色的比 如果使用蠟筆,我們需要準備3*5=15支蠟筆,也就是說必須準備15個具體的蠟筆類。而如果使用毛筆的話,只需要3 ...
  • 第一是:項目的路徑需要放在Documents and Settings\,也就是預設的文件夾的地方,不然會報錯錯誤範例為:Question:CY8CKIT-023 kit example project fails to build in PSoC Creator with the followin ...
  • 我使用的是海康DS-2CD852MF-E, 200萬,網路攝像機,已經比較老了,不過SDK在海康官網下載的,開發流程都差不多. 海康攝像機回調解碼後的視頻數據格式為YV12,順便說一下YV12的數據格式 YYYY V U. 我這個是720P,即1280 * 720解析度. 那麼Y分量的數量為 128 ...
  • 適配器模式:將一個類的介面轉換成客戶希望的另外一個介面,使得原本由於介面不相容而不能一起工作的那些類可以在一起工作。 如下圖(借圖): // 設置書的介面 客戶端測試: 輸出結果: 這時候,你想創建一個可以復用的類,該類可以與其他不相關的類或不可預見的類(即那些介面可能不一定相容的類)協同工作。 如 ...
  • 這節主要說一下Angular的指令。Angular的指令有內置指令和自定義指令。 一、內置指令 在 Angular 中通過指令對DOM的功能進行擴展。這也是對常用功能的模塊化封裝。Angular 提供了一系列常用的指令,這些指定都是以 ng 開頭的,我們稱為內置指令。 後面會講到如何自定義指令。其實 ...
一周排行
    -Advertisement-
    Play Games
  • 前言 本文介紹一款使用 C# 與 WPF 開發的音頻播放器,其界面簡潔大方,操作體驗流暢。該播放器支持多種音頻格式(如 MP4、WMA、OGG、FLAC 等),並具備標記、實時歌詞顯示等功能。 另外,還支持換膚及多語言(中英文)切換。核心音頻處理採用 FFmpeg 組件,獲得了廣泛認可,目前 Git ...
  • OAuth2.0授權驗證-gitee授權碼模式 本文主要介紹如何筆者自己是如何使用gitee提供的OAuth2.0協議完成授權驗證並登錄到自己的系統,完整模式如圖 1、創建應用 打開gitee個人中心->第三方應用->創建應用 創建應用後在我的應用界面,查看已創建應用的Client ID和Clien ...
  • 解決了這個問題:《winForm下,fastReport.net 從.net framework 升級到.net5遇到的錯誤“Operation is not supported on this platform.”》 本文內容轉載自:https://www.fcnsoft.com/Home/Sho ...
  • 國內文章 WPF 從裸 Win 32 的 WM_Pointer 消息獲取觸摸點繪製筆跡 https://www.cnblogs.com/lindexi/p/18390983 本文將告訴大家如何在 WPF 裡面,接收裸 Win 32 的 WM_Pointer 消息,從消息裡面獲取觸摸點信息,使用觸摸點 ...
  • 前言 給大家推薦一個專為新零售快消行業打造了一套高效的進銷存管理系統。 系統不僅具備強大的庫存管理功能,還集成了高性能的輕量級 POS 解決方案,確保頁面載入速度極快,提供良好的用戶體驗。 項目介紹 Dorisoy.POS 是一款基於 .NET 7 和 Angular 4 開發的新零售快消進銷存管理 ...
  • ABP CLI常用的代碼分享 一、確保環境配置正確 安裝.NET CLI: ABP CLI是基於.NET Core或.NET 5/6/7等更高版本構建的,因此首先需要在你的開發環境中安裝.NET CLI。這可以通過訪問Microsoft官網下載並安裝相應版本的.NET SDK來實現。 安裝ABP ...
  • 問題 問題是這樣的:第三方的webapi,需要先調用登陸介面獲取Cookie,訪問其它介面時攜帶Cookie信息。 但使用HttpClient類調用登陸介面,返回的Headers中沒有找到Cookie信息。 分析 首先,使用Postman測試該登陸介面,正常返回Cookie信息,說明是HttpCli ...
  • 國內文章 關於.NET在中國為什麼工資低的分析 https://www.cnblogs.com/thinkingmore/p/18406244 .NET在中國開發者的薪資偏低,主要因市場需求、技術棧選擇和企業文化等因素所致。歷史上,.NET曾因微軟的閉源策略發展受限,儘管後來推出了跨平臺的.NET ...
  • 在WPF開發應用中,動畫不僅可以引起用戶的註意與興趣,而且還使軟體更加便於使用。前面幾篇文章講解了畫筆(Brush),形狀(Shape),幾何圖形(Geometry),變換(Transform)等相關內容,今天繼續講解動畫相關內容和知識點,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 什麼是委托? 委托可以說是把一個方法代入另一個方法執行,相當於指向函數的指針;事件就相當於保存委托的數組; 1.實例化委托的方式: 方式1:通過new創建實例: public delegate void ShowDelegate(); 或者 public delegate string ShowDe ...