服务器开发-纠正以前的错误

最近一阵子没有更新Egret客户端的博客。这里要解释一下,是由于最近在忙着重写服务器。前端

为何说是重写呢?以前封装了一个websocket的中间件,已经能够实现基本的ws通讯了。可是最近和游戏那边的同事交流中发现以前对游戏服务器开发的认知错误。程序员

错误有如下几点web

  1. 服务器逻辑是单线程的。单线程逻辑更加简单,理论上不会出现数据错误问题
  2. 服务器逻辑是顺序执行的。意思就是每一个客户端的请求必须按顺序去执行,否则会出现客户端处理混乱的状况

了解到这些以后,我从新设计了一下服务器的“架构” ,或许算不上架构,我就是怎么简单怎么搞。数据库

这几天我作了如下几点:缓存

  1. 写了一个简单的服务器主循环的结构
  2. 写了一个简单Ws链接异步处理,并抛给主循环处理逻辑和处理主循环发给前端的数据包
  3. 封装了一个简单的协议格式和作了一个简单的逻辑处理的结构
  4. 实现了基本的玩家和Ws的绑定,并作是用Attribute作了简单的身份验证,缓存了反射结果,提升了性能

差很少就是这些,看起来很少,可是对于第一次摸索着写游戏服务器的人来讲,仍是很费时间的。服务器

最近收获:发现游戏服务器逻辑基本都是单线程(第一次以为CPU性能这么强劲。。),数据库查询,文件操做等耗时的内容都是在异步线程处理。处理完成后,不能再异步线程操做主循环的数据。必须把查询处理的数据抛给主循环的队列,而后由主循环的线程来处理。通常这样的才能保证游戏服务器数据不错乱和性能兼顾。websocket

网上关于游戏服务器开发的具体细节的文章太少了。感受游戏服务器开发的程序员都不怎么写博客啊。。。架构

最后感谢坐我隔壁位的隔壁的东北老铁。个人每一个问题都很仔细的给我作了解答,还给我翻出C++的代码看(虽然我看不大懂C++)。。。一段时间的交流下来,我如今口头禅都变成了:老铁,没毛病,双击666。。异步

最后东北老铁给我说其实快手的那种老铁666都是夸张了。。。socket

好了,就这样,服务器代码暂时不发出来,由于我发现还有不少完善的地方。后面能完成的跑出一个斗地主联网的游戏以后,我会发出来的。

最后但愿有大兄弟能指出个人问题。

老铁,没毛病


相关文章
相关标签/搜索