Nginx七层负载均衡

Nginx七层负载均衡

bash 复制代码
/usr/local/nginx/conf/nginx.conf # nginx配置文件
bash 复制代码
client-nginx-rs-n-c # 访问流程

1. 用户创建

bash 复制代码
useradd -M -d /usr/local/nginx/ -s /sbin/nologin nginx # 创建nginx用户

2. worker设置

bash 复制代码
nginx -s reload # 每次修改完配置后,需要重载


根据CPU的核心数自动设定

3. worker_connections设定

Linux中的设定规则是kernel>system>app

bash 复制代码
sysctl -a | grep file # 查看内核
bash 复制代码
ulimit -a  # 查看系统
bash 复制代码
vim /etc/security/limits.conf

4. 负载均衡

官方文档:https://docs.nginx.com/nginx/admin-guide/load-balancer/http-load-balancer/

  1. 在real server上修改http监听端口
  1. 在备用机器上修改http配置

成功实现了7层的负载均衡

说明:正常情况下,负载均衡;异常情况下访问备用机。

5. 负载均衡算法优化

5.1 weight(权重)
5.2 ip_hash

来自同一个客户端请求会发往同一个后端服务器交互(数据库),这种场景不适合来回切换,比较合理。

5.3

客户端访问代理(调度器),代理再去访问real server。流量首先会经过CDN代理,那么IP HASH就无法获取到真实的客户端IP。

浏览器cookie 记录信息,访问服务器。独一无二的。

  • 安装nginx-goodies-nginx-sticky-module-ng-08a395c66e42 模块

  • 重新修改配置和编译,不要install

bash 复制代码
cd nginx-1.27.1/
make clean
ls /root/nginx-goodies-nginx-sticky-module-ng-08a395c66e42
./configure --prefix=/usr/local/nginx --with-http_ssl_module --with-http_stub_status_module --add-dynamic-module=/root/nginx-goodies-nginx-sticky-module-ng-08a395c66e42
nginx -s stop
make
cp objs/nginx /usr/local/nginx/sbin/nginx

浏览器中访问,服务器不会变。

相关推荐
运维行者_8 小时前
企业无线网络监控的挑战与智能化演进趋势
大数据·运维·服务器·网络·数据库
2603_955279708 小时前
Cursor + GitOps:自动化运维新姿势
运维·自动化
Waay9 小时前
面试口述版:个人对 Prometheus 完整理解
运维·学习·云原生·面试·职场和发展·kubernetes·prometheus
三8449 小时前
文件查找/文件压缩/解压缩
linux·运维·服务器
小猪写代码9 小时前
Linux 管道(Pipeline)作业
linux·运维·服务器
桌面运维家9 小时前
如何用半缓存云桌面将服务器硬盘容量扩展至本地终端?
运维·服务器·缓存
激情的学姐9 小时前
【大型网站技术实践】初级篇:借助Nginx搭建反向代理服务器
运维·nginx
ai_coder_ai10 小时前
编写自动化脚本,在自己后端服务中使用Open Api进行设备相关操作
java·运维·自动化
spider_xcxc11 小时前
Redis 数据库高质量实践指南(一)
运维·数据库·redis·oracle·云计算
我是一颗柠檬11 小时前
【Java项目技术亮点】加权轮询负载均衡算法
java·算法·负载均衡