当前位置: 首页 > news >正文

CPP集群聊天服务器开发实践(五):nginx负载均衡配置

1 负载均衡器的原理与功能

单台Chatserver可以容纳大约两万台客户端同时在线聊天,为了提升并发量最直观的办法需要水平扩展服务器的数量,三台服务器可以容纳六万左右的客户端。

负载均衡器的作用:

  1. 把client的请求按照负载均衡算法分发到具体业务服务器chatserver上面:保证server与client的长连接,依据轮询算法/权重算法等将不同client连接到不同server上面,提升client的容量
  2. 能够和chatserver保持心跳机制,监测chatserver故障:nginx能够实时监测server是否由于网络故障无法为client提供服务,可以引入心跳计数器进行判断
  3. 能够发现新添加的chatserver设备,方便扩展服务器数量:能够在不关闭原有服务器的基础上平滑添加新的server供nginx调度分配

2 nginx的tcp负载均衡配置和功能验证

选择nginx的tcp负载均衡模块需要解决的问题:

  1. 如何进行nginx源码编译,包括tcp负载均衡模块
  2. nginx.conf配置文件中如何配置负载均衡
  3. nginx的平滑加载配置文件启动

配置参考:Nginx负载均衡实践-CSDN博客

安装好nginx之后位于usr/local/nginx之下:

配置文件位于conf文件夹下的nginx.conf,可执行文件位于sbin下。

nginx提供了应用层(http web)和传输层(tcp)的负载均衡,在nginx.conf中修改即可。

#nginx tcp loadbalance config
stream{upstream MyServer{/*weight:设置服务器权重,加权轮询算法中权重大的优先分配客户端max_fails:与server的心跳机制,超过3次未响应则认为故障fail_timeout:每次心跳监测的时长为30s添加新的服务器无需停止nginx服务,只需要修改此配置文件即可*/server 127.0.0.1 6000 weight=1 max_fails=3 fail_timeout=30s;server 127.0.0.1 6002 weight=1 max_fails=3 fail_timeout=30s;}server{proxy_connect_timeout 1s;#proxy_timeout 3s;//客户端统一连接nginx的8000端口,由nginx进行负载均衡listen 8000;//反向代理对象为MyServerproxy_pass MyServer;tcp_nodelay on;}
}

./nginx -s reload:平滑重启配置文件

./nginx -s stop:停止nginx服务

结果测试:

(1)启动nginx

(2)测试连接

两台客户端访问8000端口的nginx分别被分配到了两台服务器。

http://www.lryc.cn/news/537867.html

相关文章:

  • easyexcel解析excel文件的时候报错
  • Android设备 网络安全检测
  • word分栏使得最后一页内容自动平衡
  • 完全免费稳定WebTerm网页版在线SSH连接,在线远程连接云服务器,可以控制背景,支持SFTP访问服务器文件。无需安装即可在线连接和管理服务器的SSH终端工具。支持跨平台设备。
  • 微信小程序医院挂号系统
  • 编程题-最大子数组和(中等-重点【贪心、动态规划、分治思想的应用】)
  • 阿里云视频点播,基于thinkphp8上传视频
  • 《探秘AI绿色计算:降低人工智能硬件能耗的热点技术》
  • 神经网络常见激活函数 9-CELU函数
  • 软考高级《系统架构设计师》知识点(四)
  • opencv交叉编译
  • 安装vite报错Install for [ ‘create-vite@latest‘ ] failed with code 1
  • Spring框架中都用到了哪些设计模式?
  • LabVIEW 中 dotnet.llb 库功能
  • C# 变量,字段和属性的区别
  • wordpress模板文件结构超详解
  • android studio下载安装汉化-Flutter安装
  • 数据开放共享和平台整合优化取得实质性突破的智慧物流开源了
  • 如何设置 Nginx 连接超时并进行测试(Nginx优化)
  • springboot整合mybatis-plus(保姆教学) 及搭建项目
  • 知识管理成功:关键指标和策略,研究信息的投资回报率
  • 【算法】链表
  • 集成测试总结文档
  • 关于Dest1ny:我的创作纪念日
  • Python爬虫-猫眼电影的影院数据
  • 【计算机网络】传输层数据段格式
  • nsc account 及user管理
  • 晶闸管主要参数分析与损耗计算
  • .net6 mvc 获取网站(服务器端)的IP地址和端口号
  • 坐井说天阔---DeepSeek-R1