转载自:http://www.cppblog.com/jack-wang/archive/2009/01/02/70963.html
随着网游从业者的规模和需求不断扩大,越来越多的朋友进入了网游开发这个领域,使得市场中网游开发技术相关的需求量迅猛增长。目前,(网游)网络游戏行业比较紧缺的是具有较深技术功底的“专家型”开发者,这主要包括两个方面:服务器端设计人员以及客户端设计人员。对于网络游戏而言,由于其主要的游戏逻辑计算是在服务器端完成的,数据同步与广播信息的传递也是通过服务器完成的,所以,是否拥有一个有经验的服务器端设计人员已经成为一款网游产品能否成功的关键之一。鉴于此,本文将试图就网游服务器设计的一系列问题展开讨论和总结,笔者将结合自己的开发经验和体会,将其中各方面内容逐一呈现。希望能够对以下三类人员有所帮助:
有一定网络编程基础、准备进入(网游)网络游戏行业作服务器端设计的人员;
正在从事网游服务器设计的人员;
网游项目的技术负责人。
由于网游服务器的设计牵涉到太多内容,比如:网络通信方面、人工智能、数据库设计等等,所以本文将重点从网络通信方面的内容展开论述。谈到网络通信,就不能不涉及如下五个问题:
1、 常见的网游服务通信器架构概述
2、 网游服务器设计的基本原则
3、 网游服务器通信架构设计所需的基本技术
4、 网游服务器通信架构的测试
5、 网游服务器通信架构设计的常见问题
下面我们就从第一个问题说起:
常见的网游服务器通信架构概述
目前,国内的网游市场中大体存在两种类型的网游游戏:MMORPG(如:魔兽世界)和休闲网游(如:QQ休闲游戏和联众游戏,而如泡泡堂一类的游戏与QQ休闲游戏有很多相同点,因此也归为此类)。由于二者在游戏风格上的截然不同,导致了他们在通信架构设计思路上的较大差别。下面笔者将分别描述这两种网游的通信架构。
1.MMORPG类网游的通信架构
网游的通信架构,通常是根据几个方面来确定的:游戏的功能组成、游戏的预计上线人数以及游戏的可扩展性。
目前比较通用的MMORPG游戏流程是这样的:
a. 玩家到游戏官方网站注册用户名和密码。
b. 注册完成后,玩家选择在某一个区激活游戏账号。
c. 玩家在游戏客户端中登录进入已经被激活的游戏分区,建立游戏角色进行游戏。
通常,在这样的模式下,玩家的角色数据是不能跨区使用的,即:在A区建立的游戏角色在B区是无法使用的,各区之间的数据保持各自独立性。我们将这样独立的A区或B区称为一个独立的服务器组,一个独立的服务器组就是一个相对完整的游戏世界。而网游服务器的通信架构设计,则包括了基于服务器组之上的整个游戏世界的通信架构,以及在一个服务器组之内的服务器通信架构。
我们先来看看单独的服务器组内部的通信是如何设计的。
一个服务器组内的各服务器组成,要依据游戏功能进行划分。不同的游戏内容策划会对服务器的组成造成不同的影响。一般地,我们可以将一个组内的服务器简单地分成两类:场景相关的(如:行走、战斗等)以及场景不相关的(如:公会聊天、不受区域限制的贸易等)。为了保证游戏的流畅性,可以将这两类不同的功能分别交由不同的服务器去各自完成。另外,对于那些在服务器运行中进行的比较耗时的计算,一般也会将其单独提炼出来,交由单独的线程或单独的进程去完成。
各个网游项目会根据游戏特点的不同,而灵活选择自己的服务器组成方案。经常可以见到的一种方案是:场景服务器、非场景服务器、服务器管理器、AI服务器以及数据库代理服务器。
以上各服务器的主要功能是:
场景服务器:它负责完成主要的游戏逻辑,这些逻辑包括:角色在游戏场景中的进入与退出、角色的行走与跑动、角色战斗(包括打怪)、任务的认领等。场景服务器设计的好坏是整个游戏世界服务器性能差异的主要体现,它的设计难度不仅仅在于通信模型方面,更主要的是整个服务器的体系架构和同步机制的设计。
非场景服务器:它主要负责完成与游戏场景不相关的游戏逻辑,这些逻辑不依靠游戏的地图系统也能正常进行,比如公会聊天或世界聊天,之所以把它从场景服务器中独立出来,是为了节省场景服务器的CPU和带宽资源,让场景服务器能够尽可能快地处理那些对游戏流畅性影响较大的游戏逻辑。
服务器管理器:为了实现众多的场景服务器之间以及场景服务器与非场景服务器之间的数据同步,我们必须建立一个统一的管理者,这个管理者就是服务器组中的服务器管理器。它的任务主要是在各服务器之间作数据同步,比如玩家上下线信息的同步。其最主要的功能还是完成场景切换时的数据同步。当玩家需要从一个场景A切换到另一个场景B时,服务器管理器负责将玩家的数据从场景A转移到场景B,并通过协议通知这两个场景数据同步的开始与结束。所以,为了实现这些内容繁杂的数据同步任务,服务器管理器通常会与所有的场景服务器和非场景服务器保持socket连接。
AI(人工智能)服务器:由于怪物的人工智能计算非常消耗系统资源,所以我们把它独立成单独的服务器。AI服务器的主要作用是负责计算怪物的AI,并将计算结果返回给场景服务器,也就是说,AI服务器是单独为场景服务器服务的,它完成从场景服务器交过来的计算任务,并将计算结果返回给场景服务器。所以,从网络通信方面来说,AI服务器只与众多场景服务器保持socket连接。
数据库代理服务器:在网游的数据库读写方面,通常有两种作法,一种是在应用服务器中直接加进数据库访问的代码进行数据库访问,还有一种方式是将数据库读写独立出来,单独作成数据库代理,由它统一进行数据库访问并返回访问结果。
其中,非场景服务器在不同的游戏项目中可能会被设计成不同的功能,比如以组队、公会或全频道聊天为特色的游戏,很可能为了满足玩家的聊天需求而设立单独的聊天服务器;而如果是以物品贸易(如拍卖等)为特色的游戏,很可能为了满足拍卖的需求而单独设立拍卖服务器。到底是不是有必要将某一项游戏功能独立处理成一个服务器,要视该功能对游戏的主场景逻辑(指行走、战斗等玩家日常游戏行为)的影响程度而定。如果该功能对主场景逻辑的影响比较大,可能对主场景逻辑的运行造成比较严重的性能和效率损失,那么应考虑将其从主场景逻辑中剥离,但能否剥离还有另一个前提:此功能是否与游戏场景(即地图坐标系统)相关。如果此功能与场景相关又确实影响到了主场景逻辑的执行效率,则可能需要在场景服务器上设立专门的线程来处理而不是将它独立成一个单独的服务器。
以上是一个服务器组内的各服务器组成情况介绍,那么,各服务器之间是如何通信的呢?它的基本通信构架有哪些呢?
MMORPG的单组服务器架构通常可以分为两种:第一种是带网关的服务器架构;第二种是不带网关的服务器架构。两种方案各有利弊。
就带网关的服务器架构而言,由于它对外只向玩家提供唯一的一个通信端口,所以在玩家一侧会有比较流畅的游戏体验,这通常也是那些超大规模无缝地图网游所采用的方案,但这种方案的缺点是服务器组内的通信架构设计相对复杂、调试不方便、网关的通信压力过大、对网关的通信模型设计要求较高等。第二种方案会同时向玩家开放多个游戏服务器端口,除了游戏场景服务器的通信端口外,同时还可能提供诸如聊天服务器等的通信端口。这种方案的主要缺点是在进行场景服务器的切换时,玩家客户端的表现中通常会有一个诸如场景调入的界面出现,影响了游戏的流畅感。基于这种方案的游戏在客户端的界面处理方面,比较典型的表现是:当要进行场景切换时,只能通过相应的“传送功能”传送到另外的场景去,或者需要进入新的场景时,客户端会有比较长时间的等待进入新场景的等待界面(Loading界面)。
从技术角度而言,笔者更倾向于将独立的服务器组设计成带网关的模型,虽然这加大了服务器的设计难度,但却增强了游戏的流畅感和安全性,这种花费还是值得的。
分享到:
相关推荐
网游服务器通信架构是网络游戏开发中的核心部分,关系到游戏的稳定性和玩家体验。本文将深入探讨这一主题,为有志于网游服务器设计的开发者提供指导。 首先,网游服务器通信架构通常分为两大类:MMORPG(大型多人...
### 网络游戏服务器架构设计相关知识点 #### 一、网络游戏服务器架构概述 网络游戏服务器架构是指为了支撑大规模在线游戏的稳定运行所采用的技术体系结构。一个合理的服务器架构不仅可以提高游戏性能,还能确保游戏...
本文主要探讨了四种常见的网游服务器架构:Client/Server、Peer-to-Peer(P2P)、Hybrid Client/Server以及Multi-Server,每种架构都有其优缺点,并适用于不同类型的网络游戏。 1. Client/Server 架构是最基础的...
综上所述,网络游戏服务器架构设计是确保游戏成功运营的关键,它涉及到网络通信、数据处理、服务器负载均衡和安全等多方面的技术和策略。通过合理的服务器架构设计,可以提高网络游戏的整体性能,保证用户能够享受到...
网络游戏服务器架构是构建大型在线游戏的关键部分,它涉及到玩家体验、数据处理、网络通信等多个方面。本篇文章将探讨代理服务器在网络游戏服务器架构中的简单实践,旨在帮助开发者理解如何利用代理服务器提升游戏...
网络游戏服务器架构设计是网络游戏开发中的关键技术之一,它决定了游戏的服务质量、扩展性和可维护性。本文档以《新飞飞》为例,深入探讨了网游服务器架构的设计原理及其优化措施。 #### 二、韩版与国服架构对比 #...
3. **网关服务器**:作为客户端与游戏服务器之间的桥梁,处理网络通信,转发玩家请求,并执行初步的安全检查,如令牌验证和DoS防护。 4. **地图服务器**:负责游戏世界中不同区域的地图逻辑,管理玩家的位置和移动...
游戏服务器架构是游戏开发中的核心组成部分,它负责处理玩家交互、游戏逻辑、网络通信以及数据存储等一系列关键任务。一个高效且稳定的游戏服务器架构对于提供流畅的游戏体验至关重要。下面将详细探讨游戏服务器架构...
服务器架构设计.docx CryEngine引擎开发:体育网络游戏开发_(11).客户端与服务器通信.docx CryEngine引擎开发:体育网络游戏开发_(12).游戏逻辑实现.docx CryEngine引擎开发:体育网络游戏开发_(13).用户界面...
本文旨在介绍一种通用的棋牌类网络游戏服务端架构设计,涵盖基本架构、通信协议、多线程模型以及第三方接口等内容。 #### 二、核心问题与设计目标 在设计棋牌类网络游戏服务端架构时,需重点考虑以下几个方面: 1...
总结起来,网络棋牌游戏服务器架构是一个多层次、分布式的系统,它结合了高效通信机制、多服务器协作和模块化设计,确保了网络棋牌游戏的流畅运行和数据安全。这种架构不仅保证了游戏的稳定性,还便于系统的扩展和...
集群式游戏服务器架构设计还需要考虑网络通信效率,例如使用高效的异步I/O模型,如Windows下的IOCP,Linux下的Epoll,或者跨平台的ACE、ASIO库。这些库支持非阻塞I/O,提高了服务器处理大量并发连接的能力。 此外,...
为了解决这些问题,ACE框架应运而生,它是一种基于面向对象设计模式的通信软件开发框架,以其跨平台性、高性能和灵活性在网络游戏服务器设计与应用中表现出巨大的优势。 ACE框架的设计模式首先体现在它采用的面向...
网络棋牌游戏服务器架构设计是构建高效稳定游戏平台的关键。该架构主要分为物理架构和系统结构两个部分,旨在确保玩家能够顺畅地进行游戏并提供可靠的数据存储。 在物理架构层面,游戏系统由多个组件组成,包括中心...
总结,网络游戏服务器编程是一个包含网络通信、游戏逻辑、服务器架构、编程语言选择、协议设计、数据库管理和性能优化等多个层面的综合领域。理解并掌握这些知识点,对于开发出高性能、高并发、安全可靠的网络游戏...
1. **接入**:客户端通过Zone Connect与服务器通信,处理大容量接入,而Zone Server负责游戏逻辑。接入进程使用Epoll网络编程接口,单进程处理加密解密,通过Bus与Zone Server异步通信。 2. **动态更新逻辑**:接入...
### 基于IOCP网络游戏服务器通信层实现 #### 概述 本文档主要探讨了如何利用IOCP(I/O Completion Ports,I/O 完成端口)技术来设计并实现一个高效的网络游戏服务器通信层。在当前网络游戏开发领域中,高性能、低...
Unity3D游戏开发中的网络游戏服务器架构设计对于成为一名优秀的主程至关重要。在着手新项目时,作为主程,首要任务是明确以下几个关键点: 1. **服务器操作系统环境**:选择服务器运行的操作系统需要考虑到稳定性、...