railgun游戏服务端架构

以上是整个游戏服务器架构图,分为三部分。(这里把一个.exe服务器程序称为一个App

1.网关 GateApp,可以多个

2.路由 RouterApp,暂定一个

3.一般的业务App

 

这三部分的一个大致区别是:

GateApp是监听了一个TCP端口,用于用户客户端来连接,并主动去连接(or拨号)RouterApp

RouterApp监听了一个TCP端口,等待其他server app来连接,server app包括gate app和一般业务的app

一般业务App只主动连接Router App,与用户客户端的交互都通过gate来转发。

 

这里简单说明一下为什么业务APP不监听一个端口,然后供客户端直连?

因为原C++的服务器架构也曾经采用过这种方式,但是在实际运行中发现管理用户上下线行为很不方便。最典型的是顶号登录行为,如果用户换了一个设备登录账号,需要断开原来的设备上的客户端连接的话,那就要挨个APP通知,以断开原来的用户连接。这样子的用户管理非常不方便,所以后来更改架构,只允许客户端和GATE之间建立TCP连接,其他APP要与客户端交互都通过gate

 

PS:

这个golang的服务器框架是源于原来的C++游戏服务器框架,原来的C++游戏服务端目前最高同时在线人数在2W,目的是利用golang的高并发特性来尝试提高在线容量。

网络层在原来C++的设计思路上,还参考了

http://studygolang.com/articles/3184

https://github.com/funny/link

在这里顺便感谢一下这两位素不相识的大大


我的邮箱:914509007@qq.com


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值