`
vanadiumlin
  • 浏览: 505407 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

游戏服务器集群设计思路

 
阅读更多
    对于我们的游戏服务器端来说,除了要满足一般的MMO服务器端功能要求外,还要达到两个附加需求:
        1、高可用性
                避免任何服务的单点故障,各种关键服务都提供一定的冗余和故障自动切换机制。
        2、动态负载均衡
                游戏世界和游戏场景服务能够根据服务器网络中机器的负载情况,选择合适的宿主机器创建和动态迁移。
                提供场景动态分区的技术,支持单个场景中支持巨量玩家在线。
        因此,我们需要设计一个支持不同层面高可用性和负载均衡的游戏服务器集群系统。

        下面谈谈我的设计思路。
        不妨先从服务器运营、部署和管理的角度出发来来考虑。对于规模较大的MMO来说,服务器通常会部署在多个数据中心里。每个数据中心会集中部署大量服务器,这些服务器通常被作为一个整体来集中管理,诸如玩家看到的“网通1区”、“电信2区”这样的称呼。我把这样的一组服务器称为一个游戏域。本文主要叙述一个游戏域内的服务层次设计。

        一个游戏域内主要的组件以如下方式组织:
        游戏域
                登录服务:提供登录验证服务,在后期可能会加入登录排队服务。
                前端服务:相当于客户端和服务器端间的防火墙,提供包的验证、过滤、汇聚和分发功能。
                数据服务:提供游戏全局数据存取,如帐号信息等,通常底层由成熟的数据库支持。
                消息服务:主要指聊天、系统广播等即时消息服务,也可以提供类似信箱等非即时消息。
                游戏世界
                        游戏场景:包括集市、PvP副本、PvE副本等场景。
                                场景分区:主要用于支持同一场景中容纳巨量玩家,可以根据区域进行几何划分(参见场景集群的划分 ),也可以根据玩家关联程度等其他特性划分。

        为简化设计,考虑到应用特点,我们的系统设计为集中-分布式,而非完全分布式。
  
        对于一个游戏域来说,最顶层由域管理器(Domain Manager,DM)作为管理中心。这里的域管理器有些类似于简化的Windows域控制器(Domain Controller),主要有两方面作用:1)负责其之间下层组件的创建与负载均衡策略,如游戏世界的创建;2)作为一个服务注册中心,起到类似于全局 DNS的作用。
        在高可用性方面,我们系统中的各种组件基本都采用主节点-复制节点(Master-Repo)结构。对于游戏域而言,正常情况下,任何时刻一个游戏域中有一个唯一的负责决策的域管理器,即主域管理器(Master Domain Manager,MDM)。为满足高可用性要求,一个主域管理器会有多份拷贝,我们称之为复制域管理器(Repo Domain Manager, RDM)。注意,为简化起见,我们不提供域管理器本身的负载均衡支持,但支持域管理器的故障切换。当MDM出现故障时,系统会选择一个RDM升级为 MDM,并根据需要再启动一个RDM,以满足DM副本数量的要求。一个DM启动的时候,会发通过组播查询域中的DM,如果此时发现MDM,在MDM同意的情况下,就作为RDM与之通过数据复制进行同步;反之,如果没发现MDM,就和其他RDM协商,确定自身能否成为MDM。进一步设计和实现高可用性时,需要考虑集群脑裂的问题(split-brain,不熟悉的同学请google 之)。
        MDM还会根据管理数据服务、消息服务、前端服务和游戏世界等组件高可用性与负责均衡。

        客户端登录时,根据本地存储的服务器地址列表与登录服务器进行连接。因此,登录服务的负载均衡,可以结合DNS负载均衡或类似F5的负载均衡设备来实现。客户端一旦通过登录验证,就会由MDM选择合适的游戏前端服务器与之进行连接。
  
        为提供高可用性,前端服务(Front-end Service, FS)也采用主节点-复制节点的设计,客户端会缓存主前端服务地址(Master Front-end Service, MFS)和复制前端服务(Repo Front-end Service, RFS)地址。前端服务还用来存取独立于特定游戏世界的信息,如玩家的角色信息。

        和其他需要高可用性的服务类似,游戏世界、游戏场景和场景分区都采用Master-Repo体系结构。
        每个游戏世界有一个相应的主游戏世界服务器(Master World Server, MWS),其作用有两方面:1)管理游戏世界的全局信息;2)管理游戏场景的负载均衡和故障切换。
        每个游戏场景有一个相应的主场景服务器(Master Scene Server, MSS),其主要作用也有两方面:1)管理特定场景的全局信息;2)管理场景分区的负载均衡和故障切换。一个游戏场景可以由一个或多个场景分区组成。
        每个场景分区有一个相应的主场景分区服务(Master Scene Partion Server, MSPS),负责其中游戏实体对象的管理。通常,前端服务器将会把大多数客户端请求直接转发到玩家角色所属的场景分区中。

        对于任何一个分布式系统来说,主要有两方面功能:其一,向上提供分布式服务接口;其二,向下提供对底层分布资源的管理。以上主要介绍了游戏集群的服务接口层次。此外,如前所述,在资源管理方面,我们采用Master-Repo结构,将高可用性和负载均衡调度的功能融入到了游戏逻辑服务器中。这种设计把两种看似正交的功能耦合在了一起,增加了系统复杂性。其实,正是通过结合游戏逻辑和集群要求的特点,我们减少了额外层次,简化了系统设计和多余消息传递的开销。而且,通过采用相似的Master-Repo结构,似的集群资源调度本身也是可以在不同组件间复用的。

        在集群资源管理方面,还有一个重要的方面没有提到,那就是对物理机器资源的管理。为做到这一点,我们在每个物理节点(服务器的操作系统)中运行着一个后台服务,我们称之为节点代理(Node Agent,NA),起主要作用有两方面:1)负责监测系统CPU、内存和网络资源的情况,并提供查询接口;2)负责启动和停止其他的游戏服务进程,如前端服务器、游戏世界服务和场景服务等。在项目的后期,还可以通过NA加入一些方便系统管理的功能,如服务器端软件统一升级等。

        通过以上叙述,我们简要的介绍了支持负载均衡和高可用性的MMO服务器集群的构件和设计思路。因时间关系,还有一些构件和机制没有再这里讨论,如系统管理服务器设计,不同游戏域之间的通信等。随着项目的进展,设计思路的进一步成熟,这些话题会在后续的文章中讨论。
分享到:
评论

相关推荐

    基于云服务器集群三层分布式云监控系统的设计与实现.pdf

    3. 三层分布式云监控系统的设计思路 - 云监控系统采用三层分布式结构,包括云调度服务器、各数据中心的云监控服务器和实际提供云服务的节点服务器。 - 节点服务器负责周期性采集自身性能实时信息并报告给云监控...

    服务器集群设计.docx编程资料

    ### 服务器集群设计知识点解析 #### 一、服务器集群技术概览 服务器集群技术是一种将多台物理服务器联合起来作为一个整体向用户提供服务的技术。这项技术的出现与发展得益于服务器硬件系统和网络操作系统的进步,...

    基于netlink的linux服务器集群统一外设事件监听机制.pdf

    《基于netlink的Linux服务器集群统一外设事件监听机制》 在当前的大型分布式服务器集群系统中,由于服务器数量众多且可能分布广泛,对外设事件...同时,它也为未来服务器集群的智能化管理和自动化运维提供了新的思路。

    Linux集群环境下监控Web服务器的Shell脚本设计.pdf

    该程序的设计思路是首先检查Web服务器的进程状态,如果发现问题,则发出警告并记录日志。然后,程序会周期性地检查Web服务器的状态,并在出现问题时发出警告。 本文通过设计了一种Shell脚本守护程序,实现了对Linux...

    基于Linux集群构建网络服务器的方案分析.pdf

    服务器集群的基本思路是将多台独立服务器通过网络技术连接,形成整体对外提供服务,通过负载均衡将请求分发至各个服务器,以缩短响应时间和提升处理能力。 设计服务器集群时,应遵循以下原则: 1. 独立设计原则,...

    基于ssm+shiro+redis+nginx tomcat服务器集群管理项目源码+项目说明.zip

    基于ssm+shiro+redis+nginx tomcat服务器集群管理项目源码+项目说明.zip Introduction ==== 1.搭建一个最简洁,模块划分最明确的ssm+swargger+shiro+redis+nginx整合项目,采用maven作为构建工具,在有新项目开发时...

    开源Linux集群系统服务器池存活性技术研究.pdf

    总的来说,对于Linux集群系统的服务器池存活性的研究不仅关乎技术细节,还涉及到系统设计的整体优化和故障容错能力的提升。这项研究对于那些需要构建和维护大规模、高可用性集群环境的IT专业人士具有极高的参考价值...

    tictac:演示构建用Elixir编写的集群,分布式,多玩家,回合制游戏服务器

    这是构建以Elixir编写的集群,分布式,多玩家,基于回合的游戏服务器的演示。 按照设计,它可以玩井字游戏,但可以扩展为可以玩几乎所有多人回合制游戏。 它使用Phoenix libcluster用于UI,使用TailwindCSS进行样式...

    刀片服务器与机架式服务器比较

    首先,刀片服务器是一种高度集成的设备,其设计思路在于最大化空间利用效率。它由一系列薄型计算模块(刀片)组成,这些刀片插在统一的刀片机箱中,每个刀片相当于一个独立的服务器。这种设计减少了布线复杂性,因为...

    基于Hadoop的分布式集群大数据动态存储系统设计.pdf

    该设计工作不仅为Hadoop生态系统增加了新的功能,也为大数据存储系统的设计和优化提供了新的思路和方法。从长远看,这将有助于推动大数据技术在各行业的应用发展,为商业决策、科学研究等提供更为强大的数据支持。 ...

    2017老男孩Linux集群全网服务器数据备份方案超细实战视频课程

    ### 一、2017年老男孩Linux集群全网服务器数据备份方案概述 #### 1. Linux集群简介 - **定义**: Linux集群是指由多台运行Linux操作系统的计算机通过网络连接起来共同工作,对外提供统一的服务或计算能力的一种技术...

    高并发解决方案-提升高并发量服务器性能解决思路.docx

    ### 高并发解决方案——提升高并发量服务器性能解决思路 #### 概述 随着互联网技术的飞速发展,用户数量激增以及业务需求多样化,如何有效地处理高并发场景下的服务器性能成为了众多企业和开发者关注的重点。本文...

    第五组_服务器系统的设计方案.docx

    本方案将详细探讨校园网服务器系统和某单位服务器系统的具体设计思路与实施策略。 一、校园网服务器系统设计方案 1. 方案概述:校园网服务器系统旨在满足教育机构的信息需求,包括提供Web服务、电子邮件服务、办公...

    NC65搜索服务器使用指南

    通过这样的设计思路,搜索服务器能够专注于搜索服务的各项流程,包括数据抓取、索引构建以及结果检索等。 #### 二、部署搜索服务器的优势 1. **提高搜索稳定性**:在传统的NC65系统架构中,搜索服务分散于整个服务...

    MySQL数据库集群+负载均衡(LVS)

    **测试环境** 包括服务器分布、网络拓扑等信息,这些是搭建LVS + Keepalived + MySQL Cluster集群的基础。 1. **服务器分布** - 主LVS服务器、备用LVS服务器、Keepalived服务器以及MySQL Cluster的数据节点和SQL...

    服务器行业应用案例-网游-传奇(R).docx

    为了满足大量玩家同时在线的需求,游戏运营商需要搭建高性能、稳定可靠的服务器集群。在这种背景下,联想万全服务器成为了众多知名网络游戏的首选解决方案。 #### 服务器需求分析 网络游戏服务器与传统服务器相比...

    服务器架构1

    这种服务器架构的设计思路是模块化和分布式,能够应对高并发场景,提高系统的可扩展性和容错性。每个组件都可以根据需求独立扩展,同时通过优化通信协议和数据结构,进一步提升整体性能。此外,通过引入缓存和数据库...

    基于linux系统集群的架构与优化.pdf

    文章中,作者强调了企业级Linux集群的设计思路,即打破传统单机模式,构建基于Linux集群技术的企业网络解决方案。这个平台旨在提供高可用性、高可靠性和负载均衡,通过监控集群中各节点的负载状况,将外部请求转发到...

Global site tag (gtag.js) - Google Analytics