网狐棋牌游戏平台服务器架构设计分析

本文深入探讨了网狐棋牌游戏平台的服务器架构设计,包括基于COM组件接口模式的调用模型,事件驱动的数据处理模型,以及如何通过数据队列服务和多线程处理网络、数据库事件。此外,还详细介绍了软件的架构设计,功能模块划分,特别是数据队列服务的设计,其采用内存链表存储事件数据,并利用完成端口技术进行线程事件通知。
摘要由CSDN通过智能技术生成

基本设计概念和处理流程

 

调用模型

模仿COM组件接口模式,利用面向对象思想多态性polymorphism,调用方保存着被调用方的基础接口指针(interface or sink钩子)(Pure Virtual Function),调用方直接调用接口指针内声明的纯虚方法,而此纯虚函数的具体逻辑由该接口的派生类实现。

示意图:

 

基于事件驱动的数据处理模型

在系统功能设计中,针对网络事件SocketEvent、数据库事件DatabaseEvent、定时器事件TimerEvent……的数据处理,建立数据队列服务QueueService,为每一队列建立多个子线程QueueServiceThread处理。数据队列服务提供添加事件数据的方法AddToQueue,设置数据队列服务钩子SetQueueServiceSink,由数据队列服务钩子QueueServiceSink执行具体逻辑事件的数据处理。
示意图:


再者,根据网络、数据库等特定功能,构建网络、数据库等管理服务,实现数据队列服务钩子QueueServiceSink方法,调度事件数据执行外部处理接口,外部处理接口具体由二次开发用户实现。

示意图:

 

事件数据设计

 

软件体系结构(架构 Architecture)设计

 

功能模块划分

 

数据队列服务QueueService模块设计

    基本设计概念

    建立一个内存链表,保存事件数据,对外部提供方法(向链表添加事件数据并通知线程,同时启动多个处理线程,从数据链表里获取事件数据,执行外部钩子方法进行处理。线程事件通知采用完成端口技术。

    类与接口设计

 

COM接口 接口名 接口基类 接口实现类
A 队列引擎 IQueueServiceEngine CQueueServiceHelper
B 事件服务 IEventService CEventServiceHelper
C 网络引擎 ITCPSocketEngine CTCPSocketEngineHelper
D 定时器引擎 ITimerEngine CTimerEngineHelper
E 数据库操作 IDataBase CDataBaseHelper
F 数据库引擎 IDataBaseEngine CDataBaseEngineHelper
I 调度引擎 IAttemperEngine CAttemperEngineHelper
G 服务引擎 IServiceEngine CServiceEngineHelper
K 异步引擎 IAsynchronismEngine CAsynchronismEngineHelper
  自动清理参数辅助类   CAutoCleanParameters
  自动关闭记录集辅助类   CAutoCloseRecord
  断开数据库连接辅助类   CAutoCloseDataBase
       

 

内部接口 类别 接口 功能 继承 实现类
数据队列事件
(非组件实现)
CQueueServiceEvent
(IQueueService、CThreadLock)
设置接口、发送通知事件    
         
  数据库错误接口 IADOError 错误类型与描述 : public IUnknownEx CADOError
E 数据库连接接口 IDataBase 数据库操作类 : public IUnknownEx CDataBase
  数据库钩子接口 IDataBaseSink 启动关闭数据库模块、数据操作处理 : public IUnknownEx
F 数据库引擎接口 IDataBaseEngine 启动停止服务、注册钩子、获取接口 : public IUnknownEx CDataBaseEngine
           
A 数据队列接口
  • 3
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
Unity 对接网狐服务器 ——波波 网狐的棋牌服务器非常稳定,代码质量高,最重要的是开源。阅 读网狐的代码,自我感觉技术提高不少,真心感谢网狐网狐的 PC 客户端的代码,和服务器代码同出一辙,优秀稳定, 功能齐全。唯独移动平台的客户端的研发稍微有点落后。前几年,网 狐为 Android和 iPhone两个移动平台分别开发了大厅, 弊端显而易见, 一个游戏就会同时配有三个不同平台的客户端,也就是说,需要使用 三种编程语言来实现客户端才能满足市场的需求。 这三种语言分别是 C++,java,object-C。开发难度之大,可想而知。 2016 年 2 月,网狐终于推出了 cocos2d 的客户端,而在网狐推出 cocos 客户端之前,不少公司已经做到使用 cocos 客户端来对接网狐服务器了。然而,使用 unity 对接网狐服务器这个解决方案,网狐 迟迟还没有给出。下面简单介绍一下 unity 对接网狐服务器的解决方 案。 想对接成功,需要看懂网狐服务器代码。网狐的代码其实并不 难, 工作经验超过一年的 C++程序员应该都可以看懂的。 网狐的 6603 版和经典版服务器, 上层的功能较多, 想理清代码逻辑, 需要点时间。 建议从网狐 6601 版服务器看起。 只需要看懂下面 9 个项目工程就 OK。 编译代码的先后顺序:公共服务,网络服务,列表服务,内核引 擎,游戏服务,中心服务器,登录服务器,服务装载器。 共享组件是客户端和服务端公用的工程。其中公共服务项目会被 内核引擎使用到,编译顺序需要优先;网络服务会被登录服务器和游 戏服务使用到,编译顺序需要优先。 编译整个解决方案后,会生成三个可执行文件和多个 DLL。三个 可 执 行 文 件 分 别 是 中 心 服 务 器 CenterServer.exe , 登 录 服 务 器 LogonServer.exe,服务装载器 ServiceLoader.exe。优先启动中心服务 器,再接着启动登录服务器服务器装载器。 下面说说这三者之间的关系: 中心服务器:是登录服务器和所有游戏服务器服务器,也就是 说, 在服务器层面上, 登录服务器游戏服务器的角色是一个客户端。 中心服务器启动后,各个游戏服务器再启动。这个过程中,游戏 服务器要向中心服务器进行房间注册。然后,启动登录服务器。登录 服务器会定时地向中心服务器请求游戏房间的列表。 登录服务器:对应的客户端的大厅,大厅登录后,除了会获得当 前玩家的个人信息,还会获得游戏列表等多种信息。 游戏服务器:对应着具体的游戏客户端。由服务器装载器启动, 也就是由服务器装载器来启动各个游戏服务器项目编译出来的 DLL。 上面说法,仅仅针对网狐棋牌 6601 版本,事实上,网狐 6603 版 本在服务器结构设计上已经做了较大幅度的改动。但能看懂 6601 代 码的,也会看得懂 6603 代码,因为服务器的内核几乎没有变化,主 体架构不变。 下面开始介绍 unity 客户端。为了缩短开发示例时间,就采用 .net 的 WinForm 来做界面。代码可以直接移植到 unity。不解释。示例是 五子棋游戏。 在介绍示例前,先说说网狐的加解密方法和数据传输的协议。这 两个是难点,你能看得懂网狐的 C++版加解密方法和数据传输的协 议,并且能用其他一门语言翻译出来,就说明你的编程功底已经很不 错的,这篇漏文就不用看了,谢谢。 网狐加解密方法,是自研的。过程环环相扣,加密后的数据分析 难度大,解密难度也大。因为上一次发送的数据会作为下一次加密数 据的密钥。而上一次解密出来的数据又会作为下一次机密数据的密 钥。 就连第一次的加密密钥都是随机产生的。 应该不少公司采用 MD5 加密方法来加密数据。MD5 加密的数据是不可逆的,代价也很大。 一是 MD5 准确来说是签名,发送的数据被拦截后,整个数据包的内 容都可以分析,甚至可以换掉签名。二是,看看 MD5 的 C++实现, 就明白一次 MD5 加密会耗费多少服务器的 CPU。客户端的数据源源 不断,服务器要耗费多少时间在 MD5 加密验证上? 采用映射表和异或方法两层加密。映射方法,翻译简单。异或加 密方法,相对较难。 我用两个类来分别实现这两种加密方法。 这个过程其实并不简单。 具体看我的代码,不一一说。 接着是数据传输的协议,必须和服务器一样,才能传递正确的数 据。 难点在发送数据时,怎么组装一个命令的,并且为这个命令加密。 不一一说,具体看代码。 接下来,是大厅的介绍。 大厅要实现的功能不少,主要有注册登录获取个人信息,获取游 戏列表。其他功能,实现起来相对简单。 对应的是客户端工程的这部分代码。 再接着,是房间的功能介绍。主要包括:系统消息,公聊消息, 私聊消息,消息推送,银行操作,鲜花道具等

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值