集群聊天服务器(12)nginx负载均衡器

目录

负载均衡器

目前最多只能支持2w台客户机进行同时聊天

所以要引入集群,多服务器。

但是客户连哪一台服务器呢?客户并不知道哪一台服务器更加繁忙

选择nginx的tcp负载均衡器,能够支持至少3w并发量,最大5w-6w之间

使用nginx的负载均衡器+3台服务器,能够支持15W并发量

nginx负载均衡器优势

提高并发量

nginx可以平滑加载配置文件,不像有些公司在凌晨重启服务器。在扩展服务器上比较方便

心跳机制,监测chatserver故障

如何解决集群聊天服务器跨服务器通信问题?

集群部署的服务器之间进行通信,最好的方式就是引入中间件消息队列,解耦各个服务器,使整个系统松耦合,提高服务器的响应能力,节省服务器的带宽资源。

采用基于发布-订阅的redis消息队列

消息队列相当于一个观察者,会把监听者感兴趣的推送给监听者。而监听者需要先订阅。这就是观察者模式的一个应用场景。

nginx的TCP负载均衡配置

nginx从1.9版本之后支持tcp的长连接负载均衡,但是默认没有编译tcp负载均衡模块,编写时需要加入-with-stream参数来激活这个模块。

nginx配置

先解压

./configure --with-stream

如果报错:./configure: error: the HTTP rewrite module requires the PCRE library.:

sudo apt-get install libpcre3 libpcre3-dev

然后make && make install

安装到了其他目录



在8000这个端口号上进行监听。

weight是权重的意思,权重都为1,那就是轮询,给两台服务器发送。如果上面1,下面是2,那么就是来3个请求下面拿到两个。服务器硬件性能高一点的可以权重大一点。max_fails是心跳机制,等待服务器回消息,等待时间30s,如果心跳超过3次都失败,那么就判定该服务器挂了。

如果要添加服务器,那就是在这里面继续往后写。

转到sbin目录下

先启动./nginx

然后nginx -s reload平滑启动

然后给chatserver的main.cpp加了参数

同时开启两个服务器

两个客户端先连接8000端口

服务器通过轮询一边连接了一个

在其中一个客户端登录,一个服务器响应了

相关推荐
weixin_604236672 小时前
华三 路由器 极简核心配置
运维·服务器·网络·h3c·h3c路由器
鹤落晴春2 小时前
【Linux复习】管理SELinux安全性
linux·运维·服务器
杨了个杨89824 小时前
Keepalived + Nginx + HAProxy 高可用架构部署实战案例
java·nginx·架构
lizhihai_997 小时前
股市学习心得-AI 产业链核心标的梳理清单
大数据·服务器·人工智能·科技·学习
黄同学real7 小时前
解决 Visual Studio Web Deploy 远程发布报 401 未授权 (ERROR\_USER\_UNAUTHORIZED)
服务器
天天进步20158 小时前
Tunnelto 源码解析 #9:控制服务器设计:Warp、WebSocket、Ping/Pong 与连接保活
运维·服务器·websocket
Java面试题总结9 小时前
Linux-Ubantu-贴士-apt的地盘
linux·运维·服务器
●VON9 小时前
AtomGit Flutter鸿蒙客户端:数据模型
android·服务器·安全·flutter·harmonyos·鸿蒙
酉鬼女又兒9 小时前
零基础入门计算机网络:网络层核心任务、三大关键问题、两种服务类型与 TCP/IP 网际层协议体系全解析
服务器·网络·网络协议·tcp/ip·计算机网络·php·求职招聘
Gauss松鼠会10 小时前
【GaussDB】GaussDB重要通信参数汇总
服务器·网络·数据库·sql·性能优化·gaussdb·经验总结