美文网首页Java游戏服务器开发
游戏服务器动态伸缩设计

游戏服务器动态伸缩设计

作者: 王广帅 | 来源:发表于2017-07-23 21:44 被阅读78次

一台服务器的承载量是有限的,对于一个区来说,平时可能只需要支持500到1500人左右,这样一台服务器可能就可以搞定,但是如果有运营搞活动,打广告拉流量,可能一个区的承载量需要支持300到6000的量,甚至更多。为了适应这样的不同情况,在游戏服务器设计的时候,最好能做到服务器可以动态扩展和收缩,可以根据情况,运行不同的服务器配置。

玩家进入游戏之前就要确定进入哪个区,这个区在哪个服务器上面是由服务器端分配的。所以需要以下几张表,来存储游戏的区信息和服务器信息

1,游戏区信息表

分区ID,分区名字,分区状态(主要是:新区,热门,活跃,维护等)

2,游戏区对应的服务器表

分区ID,服务器Id,服务器ip,服务器端口,服务器状态(正常,不可用等),当前在线人数(在分配服务器做为参考值),权重值

第二张表是一个一对多的关系,一个区对应多个服务器地址,当用户选择某一个区之后,向服务器请求获取这个区所在的服务器地址。这时,服务器可能根据当前区所对应的服务器的在线人数或者其它条件,按照一定的算法,给当前玩家分配一个可以连接的服务器地址,返回它的ip和端口。这样就可以实现服务器的动态扩展了,当一个区需要增加承载量时,只需要给这个区增加服务器数量即可。当流量减少,稳定之后,可以减少服务器数量。

分配服务器地址的算法一般有以下几种:

1,用户id求余法

假如当前一区对应着6台服务器,当用户选择一区时,可以根据用户的id和服务器数量求余,比如serverIdIndex = userId % 6,serverIndex的值是0到5之间的某个值。这个算法可以让同一台用户使用分配到同一台服务器上面。

2,加权随机法

假如当前有一区对应3台服务器A,B,C,它们有一个权重的属性,A(1),B(3),C(4),可以这样计算:

代码请到此查看,简书的编辑器对代码支持太差了:http://www.coc88.com/h-nd-166.html?_np=2_323 

3,轮询法

这个是按照请求顺序,比如一个区对应3台服务器A,B,C,第一个用户请求时分配A,第二个用户分配B,第三个用户给C,每四个用户再给A,如果循环下去。

4,最小在线人数

这个应该是最精确的,不过需要统计每个服务器的在线人数,每次用户请求分配服务器时,遍历服务器列表,把最小在线人数的服务器地址分配给这个用户。

如果游戏服务器没有网关,以上方案可以直接使用,如果游戏服务器有一层网关,需要添加网关的信息,分配给用户的连接地址就是网关的地址,一个区可能对应着一个网关,一个网关对应多个服务器,确定网关之后,再确定网关之后哪个服务器处理业务消息,需要给客户端再分配一个服务器ID,网关根据服务器的ID转发客户端的请求。

在实际应用可,可能会有更多的条件加入进来,以确定用户连接到哪个服务器,比如服务器是否在维护状态,人数是否过多等等,所以要根据实际情况选择和设计。

相关文章

  • 游戏服务器动态伸缩设计

    一台服务器的承载量是有限的,对于一个区来说,平时可能只需要支持500到1500人左右,这样一台服务器可能就可以搞定...

  • 《GOS》结构设计

    框架结构图 框架简介 《GOS》是一款基于Go语言的分布式游戏服务器框架,高可用、动态伸缩、在线扩容,可应用于市面...

  • 6. 永无止境:网站的伸缩性架构

    网站架构的伸缩性设计 一. 不同功能进行物理分离实现伸缩(新增服务器总是从现有服务器中分离出部分功能和服务): 纵...

  • 网站技术架构与性能优化(伸缩性架构)

    一.伸缩性设计模式 一).不同功能进行物理分离实现伸缩 应用服务器 => 数据库分离 => 缓存分离 => ...

  • 大型网站技术架构——6. 网站的伸缩性架构

    6. 网站的伸缩性架构 网站伸缩性:不需要改变网站的软硬件设计,仅仅通过改变部署的服务器数量就可以扩大或者缩小网站...

  • Kubernetes 动态伸缩

    1. 概述 1.1 Metrics-server 从 Kubernetes 1.8 开始,资源使用指标(如容器 C...

  • [架构设计]应用可伸缩架构分析

    引言 网站的伸缩性是指不需要改变服务器的硬件设计,仅仅靠改变应用服务器的部署数量,就可以扩大或缩小服务器的处理能力...

  • 2014TPAMI-(FLANN近似KNN算法)Scalable

    标题:可伸缩的高维数据近似搜索算法 编者的总结 本文的贡献之一是设计了K-means tree,方法简单,动态搜索...

  • 理解一致性哈希算法

    场景分析 在分布式缓存的伸缩性设计中,最主要的目标就是在新加入缓存服务器后,应该使整个服务器集群中已经缓存的数据尽...

  • Consistent Hashing

    一致性哈希是一种应对系统存储架构扩展的技术,主要应用的场景提供可伸缩(根据负载动态的添加和移除)的缓存服务器,其次...

网友评论

    本文标题:游戏服务器动态伸缩设计

    本文链接:https://www.haomeiwen.com/subject/fizmkxtx.html