【转】分布式websocket服务器

最近在开发一个游戏的客服系统,同一时间咨询问题的玩家多,为了保证服务器高可用,需要利用分布式,另外服务器宕机还需要玩家无感知重连,最关键的一点是如何实现服务器的高扩展性,即性能不足时,如何以最少的代价增加一台新的服务器。

1.单台websocket

单台消息互传实现十分简单,通过websocket中转就可以了,不再多加赘述。

2.多台websocket

当客户端不在同一台服务器上时,如何实现消息互通?

一开始的时候,我是想着把server A 与 server B 通过websocket连接起来,互发消息,这种方案在服务器数量小的时候,维护起来也不算麻烦。

例如增加server C 就要把 A、B、C连起来,但是每增加一台服务器,工作量指数级增长,还要考虑到服务器宕机、服务器心跳的各种问题,想想都头疼。

3.多台websocket消息推送

这下舒服了。

1.使用全局redis存储客户端与服务端的关系;

2.webscoket服务器各自订阅不同的消息队列。

发消息流程:

情况一:

clientA 给 clientB 发消息时,先从缓存中读取clientB在哪个服务器上,发现clientA 与clientB 在同一服务器时,消息直接发送至clientB

情况二:

clientB 给 clientC 发消息时,从缓存中读到clientC和clientB并不在同一服务器上,例如clientC在wsB,那么clientB将消息发送到rabbitmq队列B,然后rabbitmq推送到wsB,wsB给clientC发送消息。

4.总结

  1. 新增服务器只需要多订阅一条消息队列。
  2. 服务器宕机时,客服端重连websocket,重新绑定redis的server关系。
  3. rabbitmq的ack机制保证消息的可靠性。

5.改进

压缩消息,节省带宽。推荐使用google的protobuf,就是稳。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/437061.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【Rational Rose使用笔记】协作图

例题 用例题亲自画一下是最好的。 例题出处:掌握在Rational Rose中绘制协作图(交互图)的操作方法 其他参考文章: UML–协作图详解UML中创建对象的方法:Rational Rose建立对象图 笔记 以下是总结的一些笔记&#x…

python输入城市名称_python 查询天气(输入城市名,输出天气)

python 查询天气,输入城市名,输出天气def get_whether(city_name):""""""city_code_dict { \北京: 101010100, 上海: 101020100, \天津: 101030100, 重庆: 101040100, \}if len(city_name) 0:print "city name is …

【转】RocketMQ的一些特性(生产者消费者配置参数的含义)

一 nameserver 相对来说,nameserver的稳定性非常高。原因有二: 1 nameserver互相独立,彼此没有通信关系,单台nameserver挂掉,不影响其他nameserver,即使全部挂掉,也不影响业务系统使用&#xff…

【Rational Rose使用笔记】用例图

一 先找例题: 掌握运用Rose工具绘制用例图的基本操作 再学习: UML建模——用例图(Use Case Diagram) 二 下面是笔记: 了解几种关系:依赖、关联、泛化、包含、扩展。 如何区别依赖、关联? 依…

【转】使用IIS做HTTP和WebSocket服务的反向代理

反向代理对于服务器来说是非常实用的功能,可以将毫不相关的网站部署到同一个域名下,对于使用docker的人来说可以免去大量配置上的麻烦。它还能将HTTP流量转换成HTTPS,多个服务只需要一个证书就能解决。 对于nginx和Apache,网上已…

【OSG】基础知识点合集

三大遍历:更新遍历、拣选遍历、绘制遍历

sqlserver获取当前时间_c#获取并显示当前日期时间

主要使用ToLongDateString、ToShortDateString、ToLongTimeString、ToShortTimeString、DayOfWeek等获取日期、时间、星期等数据。MM 两位数月份mm 两位数分钟HH 两位小时,24小时制hh 两位小时,12小时制string br ""; string a1 D…

【考研计算机】AOE关键路径

介绍 数据结构AOE网 计算题专题:关键路径法(CPM) 需要注意的点: 最重要的点,以下图为例: 一个活动有多个入口,这是表示此活动必须在前置的多个入口都完成时,才能开始。 即,开始条件 入口1 &…

【转】.NET程序内存分析工具CLRProfiler的使用

大家都知道.net有一套自己的内存(垃圾)回收机制,除非有一些数据(方法)长期占有内存不随着垃圾回收功能而释放内存,这样就造成了我们经常说的内存泄露、内存持续增长得不到释放等问题导致APS.net网站或者C/S…

【数据库】关系数据库理论学习

学习资源 关系型数据库的基本理论 关系数据库规范化理论PPT 笔记 三个范式总结: 第一范式:保持列最简,也就是分解列。第二范式:消除非主属性对候选码的部分函数依赖。也就是n:1,有冗余,必须分解成多个表…

sql over函数_SQL 高级函数

今天是高端局,都是超级高大上的内容,惯例上目录今天觉得红黑配色好好看呀今天没有什么具体的栗子合集,大家的应用场景都很不一样,so,到具体知识点,我们再具体举栗子。窗口函数概念: 窗口函数&am…

【转】SVN各种颜色状态

黄色感叹号(有冲突): 这是有冲突了,冲突就是说你对某个文件进行了修改,别人也对这个文件进行了修改,别人抢在你提交之前先提交了,这时你再提交就会被提示发生冲突,而不允许你提交,防止你的提交覆盖了别人的…

实现二分归并排序算法_如何实现归并排序?

归并排序归并排序是分而治之的排序算法。划分步骤很简单:将当前数组分成两半(如果N是偶数,则将其完全平等,或者如果N是奇数,则一边稍大于一个元素),然后递归地对这两半进行排序。递归写法归并排序递归写法的思想是&…

通俗解释非对称加密

通俗解释 对称加密 对于不了解非对称加密的同学,应该只知道“对称加密”。这个对称是指什么呢? 加密必然要解密。如果加密和解密用的是同一串字符串,也就是密码,那么这就称为对称的。新词汇而已,为了和非对称加密相区…

【转】解决WCF大数据量传输 ,System.Net.Sockets.SocketException: 远程主机强迫关闭了一个现有的连接...

开发中所用的数据需要通过WCF进行数据传输,结果就遇到了WCF大量传输问题 也就是提示System.Net.Sockets.SocketException: 远程主机强迫关闭了一个现有的连接 网上解决方案都是千篇一律互相转发的,并且没有明确的解决方案或者按照,各个博客中…

【手算】逆序数树形计算方法

计算过程: 给定一列数,从左向右,依次将每个数拿出来,作为一棵树的树根。从剩下的数中,找比此数小的数,作为子节点加入到树中。重复1、2,直到到达最后一个数停止。 数出二级节点,即…

python 惰性_Django中的“惰性翻译”方法的相关使用

使用 django.utils.translation.gettext_lazy() 函数,使得其中的值只有在访问时才会被翻译,而不是在 gettext_lazy() 被调用时翻译。例如:要翻译一个模型的 help_text,按以下进行:from django.utils.translation impor…

【转】SVN冲突出现场景

如今是一个团结协作的时代,开发一个系统,往往会多人协作共同完成。版本管理是必不可少的,常用的软件有Git,SVN等。今天说一下,SVN管理版本时,如果出现冲突后,如何快速解决冲突。 首先说明一个问…

Qt Creator和Visual Studio双环境开发技能攻略

前言 刚接触Qt开发时,大多数同学的第一行Qt代码是在Qt Creator中写下的。 众所周知,Qt Creator是Qt官方提供的Qt集成开发环境1,提供了对Qt应用开发的全过程支持。也就是说,使用Qt Creator做Qt开发是完全够用的。不管是在Windows…

大疆无人机高程不准_大疆消费级无人机快速倾斜摄影测量实践

摘要:分别用 RTK两种测量模式测定像控点,用大疆消费级无人机 Phantom4PRO 开展倾斜摄影测量,最后进行成果检验。结果表明:RTK 电台模式(不做坐标校正,精度低)、RTK-CORS 网络模式测定像控点都能…