pomelo 开发棋牌手游 架构

一、整服务器部署架构。
服务端包含:两组server

connector server :  用于建立后维护长连接、根据用户不同的ip一致性hash分配到固定server; 维持session; 路由转发
room Server:
一个room server 代表一个游戏房间, 例如初级房、中级房等。只有同一房间的用户可以组成游戏。room server 维护游戏牌局信息,处理开始,叫分,出牌,游戏结束等所有业务逻辑。
room Server 同各个connector server 都保持一个长连接socket通信。
目前:只有同房间的用户可以互相聊天。
在room server,  根据游戏用户session中存储的connector id, 找到同游戏用户建立长连接的connecotr server,  通过channel service 将room server中产生的消息,下发到各个用户。


二、room server 设计(以斗地主为例)。
在每个room server 的进程中都各自包含一个单例的room service 对象。
在进程启动时room service 对象负责初始化100张桌子,这200张桌子永久存在。
每个桌子对象里,包含一个poker对象,poker 对象用户初始化手牌,记录出牌,炸弹等信息,保持当前游戏的各用户手牌信息; poker对象在一句游戏结束时重新初始化。
room service 对象中包含一个players[]数据,存储登录到当前房间的所有用户。 定时器没3秒检查,将举手的但不在牌桌中的用户每3个一组组成牌局,同时将不在游戏中的离线用户以及2分钟内没举手的用户踢出房间。


 
 三、出牌的处理流程
client 发出playHandle.doPushCards 请求时。
框架中有connector server 将dopushcards请求路由到后端的 room server 服务器, 交个它的playHandler 的doPushCards方法处理
playHandler通过请求的 uid获取得到room service 中的player对象,调用player对象的doPushCards方法。
如过dopushcards为最后一轮牌,游戏介绍,在desk对象中emit  gameOver事件,用于持久化数据。


https://github.com/NetEase/pomelo

https://github.com/NetEase/pomelo/wiki/Home-in-Chinese
 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值