前言:
  最近研究了一些游戏服务器的架构和实现, github上找了几个开源的实现. 有几个感觉不错, 打算仔细研读一下.
  游戏服务器种类繁多, 这边主要是基于状态同步的棋牌类游戏, 适合入门, ^_^.

研究案列:
  cashino-server(git地址, 请点击这里)这个项目好像是中国人写的, 从文档和提交者可以略见端倪, 代码是基于nodejs实现, 后端唯一的中间件是redis.
  项目非常的强大, 可以说实现了一个分布式的版本, 可扩展性强. 添加新的棋牌游戏, 按照固定的套路实现即可. 当前主要实现了2款游戏, 德州和炸金花, 基本上是中外人民喜闻乐见的娱乐项目, ^_^.

解读架构:
  一般的棋牌类游戏都有一个大厅服务器和具体的游戏(房间)服务器, 这边的架构实现也不例外.
  
  其由一个大厅服务器(集lobby, user, gateway), 和具体的游戏服务(cashino)组成. 整个游戏服务架构舍弃了常规的服务注册定位和路由模式, 巧妙地借用发布订阅模式来实现整合. 房间用户数据实时落中心化的存储. 客户端不再需要另起socket直连房间服务, 大厅服务本身可以无状态多节点部署. 当然这一切都是redis的功劳, 或者说项目作者对redis的魔性使用.
  

  login server和game server之间, 不再有http/rpc的直接交互, 只有借助redis队列实现的发布订阅关系. 这就是这个项目和其他常规棋牌类游戏服务架构的最大不同.

浅谈消息机制:
  客户端(h5, android/ios)和login server是基于websocket构建的长链接, 后续的消息交互都是通过login server中转.
  而服务内部其消息通讯机制, 正如上图的构建中, 全通过订阅/发布的消息队列来实现的.
  玩家发往房间的消息, 是通过login server节点, 往房间相关的队列推送消息, 对应的game server节点会消费并处理消息. 反之房间发送给玩家的信息, 则往用户对应的队列推送消息, 对应的login server节点会接受, 并同步返回给玩家.
  login server和game server彼此没有直接交互, 而且登陆于不同login server节点的玩家, 也能在同一个房间一起玩.

整体评价:
  cashino-server写于3年前, 应该还是属于研究试验型的阶段, 没有经历过真正商业化的考验. 
  架构上有它独创的一面, 巧妙地利用发布订阅的模式, 解决了内部交互的复杂度. 同时该设计对扩展友好, 可以非常方便扩展新的游戏(房卡模式的棋牌类), 只需要关注游戏本身逻辑就行.

总结:
  后续会再写几篇文章, 更加深入去研究剖析下该项目, 希翼从中获取更多的知识.

源码casino-server剖析(1)--游戏服务的整体架构和实现的更多相关文章

  1. Tomcat源码分析二:先看看Tomcat的整体架构

    Tomcat源码分析二:先看看Tomcat的整体架构 Tomcat架构图 我们先来看一张比较经典的Tomcat架构图: 从这张图中,我们可以看出Tomcat中含有Server.Service.Conn ...

  2. [源码解析] 模型并行分布式训练Megatron (2) --- 整体架构

    [源码解析] 模型并行分布式训练Megatron (2) --- 整体架构 目录 [源码解析] 模型并行分布式训练Megatron (2) --- 整体架构 0x00 摘要 0x01 启动 1.1 分 ...

  3. 《Spring源码深度解析》学习笔记——Spring的整体架构与容器的基本实现

    pring框架是一个分层架构,它包含一系列的功能要素,并被分为大约20个模块,如下图所示 这些模块被总结为以下几个部分: Core Container Core Container(核心容器)包含有C ...

  4. 项目源码--Android迷幻岛屿综合游戏

    下载源码 技术要点: 1.游戏开发综合技术 2.多线程机制实现游戏逻辑 3.自定义控件,系统控件等综合图层的使用 4.图层素材动画的综合技术 5.游戏算法的实现 6. OpenGL ES的综合使用 7 ...

  5. MyBatis 源码篇-MyBatis-Spring 剖析

    本章通过分析 mybatis-spring-x.x.x.jar Jar 包中的源码,了解 MyBatis 是如何与 Spring 进行集成的. Spring 配置文件 MyBatis 与 Spring ...

  6. [源码解析] PyTorch 分布式之弹性训练(4)---Rendezvous 架构和逻辑

    [源码解析] PyTorch 分布式之弹性训练(4)---Rendezvous 架构和逻辑 目录 [源码解析] PyTorch 分布式之弹性训练(4)---Rendezvous 架构和逻辑 0x00 ...

  7. [源码解析] PyTorch 分布式(10)------DistributedDataParallel 之 Reducer静态架构

    [源码解析] PyTorch 分布式(10)------DistributedDataParallel之Reducer静态架构 目录 [源码解析] PyTorch 分布式(10)------Distr ...

  8. Derek解读Bytom源码-Api Server接口服务

    作者:Derek 简介 Github地址:https://github.com/Bytom/bytom Gitee地址:https://gitee.com/BytomBlockchain/bytom ...

  9. zabbix源码安装后,设置为服务启动和关闭

    zabbix源码安装,使用service启动与关闭服务 1. zabbix客户端的系统服务脚本 1.1 拷贝启动脚本 zabbix的源码提供了系统服务脚本,在/usr/local/src/zabbix ...

随机推荐

  1. python2.7 与python3.X区别

    1,print("中文") python2.7,会报错  原因:py2.7用ascll码 解决:2.7头部加入并保存的文件用utf-8编码 # -*- coding: utf-8 ...

  2. Go的流程控制

    流程控制 Go语言支持最基本的三种程序运行结构:顺序结构.选择结构.循环结构. 顺序结构:程序按顺序执行,不发生跳转. 选择结构:依据是否满足条件,有选择的执行相应功能. 循环结构:依据条件是否满足, ...

  3. Mybatis源码解析(一) —— mybatis与Spring是如何整合的?

    Mybatis源码解析(一) -- mybatis与Spring是如何整合的?   从大学开始接触mybatis到现在差不多快3年了吧,最近寻思着使用3年了,我却还不清楚其内部实现细节,比如: 它是如 ...

  4. Mybatis中的缓存管理

    目录 Mybatis中的缓存管理 查询缓存工作原理: 配置缓存: 默认配置: 使用二级缓存: 刷新缓存过程: 配置EHcache 产生脏数据 使用原则: Mybatis中的缓存管理 查询缓存工作原理: ...

  5. laravel框架之状态更改

    //表单@if($v['sex']==0) <td class="se" ss="{{$v['sex']}}" id="{{$v['id']}} ...

  6. vulnhub AI: Web: 1

    vulnhub AI: Web: 1 提取flag攻略 导入虚拟机,开机. 扫描NAT的C段,确定虚拟机IP和开放端口. 尝试访问该网站 发现什么都没有,抽根烟冷静一下...... 来波目录扫描吧 使 ...

  7. VBA笔记

    1.VBA数据类型 数据类型 存储空间大小 范围 Byte 1个字节 0-255 Boolean 2个字节 true或false Integer 2个字节 -32768-32767 Long 4个字节 ...

  8. xamarin Mqtt

    1 什么是MQTT? mqtt (Message Queuing Telemetry Transport,消息队列遥测传输)是 IBM 开发的一个即时通讯协议,有可能成为物联网的重要组成部分.MQTT ...

  9. Mybatis 子查询

    在查询数据库时,需要以查询结果为查询条件进行关联查询. 在mybatis中通过association标签和collection标签实现子查询. 1. collection(集合)和associatio ...

  10. XGBoost 参数介绍

    XGBoost 的设置有三种参数:一般参数,提升参数和学习参数. 一般参数 取决于提升器,通常是树或线性模型提升参数 取决于选择的提升器的相关参数学习参数 取决于指定学习任务和相应的学习目标一般参数 ...