一次关于游戏服务器底层通信架构的重构过程

原创 2004年08月26日 13:18:00

从昨晚七点,到今天上午11点,先后对大厅和房间服务器进行了重构,重构后的代码结构清晰了,效率也提高了,觉得这次的重构过程很有意义,所以记录下来以备查。

在原有的大厅服务器中,原有的设计是使用统一的一个TUSER对象管理底层数据的接收以及高层对TUSER进行的逻辑层的属性读写操作,不管是玩家正常连接的SOCKET还是用于临时通信的SOCKET,只要有连接都会分配一个TUSER对象。而在TUSER对象中,又都包含大致这两方面的信息:一方面的信息是用于底层数据通信的,比如接收缓冲区数组,接收缓冲区大小等属性;而另一方面的信息则是逻辑层的玩家对象定义,包括:玩家账号、性别、年龄等属性。在原有的设计中,没有将这两个方面的信息进行进一步的划分,而是统一放在了一个TUSER里面。这样作,就存在一个问题,对于一些非正常玩家的连接,比如玩家注册或者是其它服务器与该服务器通信用的SOCKET,只要有连接,就要建立TUSER对象(因为TUSER里面有接收数据缓冲区,而所有的数据通信必须要用各自的缓冲区来作),这样TUSER对象的一些玩家属性就没有利用起来,从而导致浪费了大量的内存空间。

新的结构中,将TUSER对象一分为二,将其中有关底层通信的数据和方法分离出来,形成一个新的对象:TCONN,TCONN专门用来处理各玩家的底层通信数据和维护各玩家自己的接收缓冲区,在SOCKET的RECV里,将根据TCONN以及接收到的新数据形成一个个的逻辑数据包提交给更高层的逻辑来处理,而在其后的高层逻辑中就包含对TUSER对象的维护。这样一来,当TCONN分离出来的数据包,是要求对TUSER对象进行维护时,就在高一层的逻辑里维护TUSER,而当TCONN分离出来的数据包是要求对TABLE或其它对象进行维护时,就不用再搭载上TUSER对象。也就是说,TUSER对象的生与死,是完全按照高层逻辑在走,而不是按照网络连接和断开来走,这样分出来的两个对象应该是较好地区分了网络底层与游戏逻辑两个方面,使其彼此可以基本脱离,具有更好的扩展性和无关性。

进行了此项重构后,无意中解决了这样一个BUG:用户从桌子退出时有时无法在房间里更改状态的问题。

一种高性能网络游戏服务器架构设计

网络游戏的结构分为客户端与服务器端,客户端采用2D绘制引擎或者3D绘制引擎绘制游戏世界的实时画面,服务器端则负责响应所有客户端的连接请求和游戏逻辑处理,并控制所有客户端的游戏画面绘制。客户端与服务器通...
  • yh1548503342
  • yh1548503342
  • 2014年12月05日 17:34
  • 9565

关于游戏架构设计的一些整理吧

在单位设计上必须冲头到尾贯彻面向对象的“继承”观念 先设计基础单位A ,再在之上扩展到所有的单位, 也就是说,所有的普通单位都可以追溯到一个起源的对象, 否则代码量会让你想死 然后就能获得所有...
  • pbymw8iwm
  • pbymw8iwm
  • 2016年02月26日 15:58
  • 21981

关于游戏服务端架构的整理

一个大型的网落游戏服务器应该包含几个模块:网络通讯,业务逻辑,数据存储,守护监控(不是必须),其中业务逻辑可能根据具体需要,又划分为好几个子模块。 这里说的模块可以指一个进程,或者一个线程方式存...
  • LANGZI7758521
  • LANGZI7758521
  • 2016年09月29日 17:44
  • 2401

一次访问Web服务器的详细通信过程

转自:闲云野鹤 Internet中一台计算机访问Web服务器的全部过程,从中可以窥探Internet是如何工作的,本讲中会涉及到网络(或Internet)的专业术语、概念及Internet的重要内容,...
  • giigbox
  • giigbox
  • 2013年09月02日 21:35
  • 526

游戏服务器之多进程架构通信

http://blog.csdn.net/chenjiayi_yun/article/details/18891591 游戏服务器有时需要分多个进程来处理各种负载。多个进程之间的...
  • y13156556538
  • y13156556538
  • 2017年04月22日 16:31
  • 150

游戏服务器之多进程架构通信

2、进程内的网络相关线程类型 进程内的网络相关线程类型(不包括主线程和逻辑线程),处理进程间通信需要处理的连接的数据发送和接收。 、被动连接相关 被动连接线程池 (1)...
  • yiling2012
  • yiling2012
  • 2014年06月18日 10:46
  • 305

vc socket 多线程 (记录一次自己调用window 底层API编写 vc socket 多线程的服务器网络程序)

我写的上一个网络程序是调用MFC库的CAsyncSocket(异步非阻塞)类完成的,根据网上的描述,这种类是基于Window的消息机制实现的,收到socket消息会调用OnXX(例如:Onreceiv...
  • u013030599
  • u013030599
  • 2016年08月25日 15:18
  • 488

(坑!!待补)Linux____基础API底层执行过程(网络通信)

accept接收连接过程 TCP消息发送过程 TCP消息接收过程 TCP连接关闭过程 ——————————————accept接收连接过程———————————— 三次握手过程中内核...
  • u010241120
  • u010241120
  • 2015年09月01日 16:18
  • 290

Android底层原理之从Binder源码分析Android进程间通信过程

本文从Binder源码中分析Android底层进程间通信的过程;希望大家能耐心看下去; 首先看头文件:#include #include #include #include #include...
  • jike0901xuye
  • jike0901xuye
  • 2015年08月15日 19:52
  • 694

TCP/IP详解(卷2实现)学习笔记(一)udp的socket通信过程底层实现概述(1)

本文主要根据一个基本的BSD网络udp通信程序过程来阐述其在内核实现的基本情况。菜鸟水平有限,请谅解。 (一)个基本的BSD网络udp通信程序过程: 1.创建udp  socket;(socket) ...
  • SX_ZXL
  • SX_ZXL
  • 2014年12月01日 21:54
  • 1785
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:一次关于游戏服务器底层通信架构的重构过程
举报原因:
原因补充:

(最多只允许输入30个字)