网站首页 > 技术教程 正文
Nginx配置负载均衡
使用nginx来配置负载均衡也是比较简单的
首先在http块中配置虚拟域名所对应的地址
# 负载均衡
upstream myserver {
server 127.0.0.1:8080;
server 127.0.0.1:8082;
}
可以配置的参数有以下选项 #down 不参与负载均衡
#weight=5; 权重,越高分配越多 #backup; 预留的备份服务器
#max_fails 允许失败的次数
#fail_timeout 超过失败次数后,服务暂停时间
#max_coons 限制最大的接受的连接数
#根据服务器性能不同,配置适合的参数
然后在server块中配置监听
server {
listen 9000;
server_name localhost;
location / {
root html;
index index.html index.htm;
# 对应上述upstream所配置的名称
proxy_pass http://myserver;
### 下面都是次要关注项
proxy_set_header Host $host;
proxy_method POST;
# 指定不转发的头部字段
proxy_hide_header Cache-Control;
# 指定转发的头部字段
proxy_pass_header Server-IP;
# 是否转发包体
proxy_pass_request_body on | off;
# 是否转发头部
proxy_pass_request_headers on | off;
# 显形/隐形 URI,上游发生重定向时,Nginx 是否同步更改 uri
proxy_redirect on | off;
#允许客户端请求的最大单文件字节数
client_max_body_size 10m;
#缓冲区代理缓冲用户端请求的最大字节数
client_body_buffer_size 128k;
#nginx跟后端服务器连接超时时间(代理连接超时)
proxy_connect_timeout 90;
#后端服务器数据回传时间(代理发送超时)
proxy_send_timeout 90;
#连接成功后,后端服务器响应时间(代理接收超时)
proxy_read_timeout 90;
#设置代理服务器(nginx)保存用户头信息的缓冲区大小
proxy_buffer_size 4k;
#proxy_buffers缓冲区,网页平均在32k以下的设置
proxy_buffers 4 32k;
#高负荷下缓冲大小(proxy_buffers*2)
proxy_busy_buffers_size 64k;
#设定缓存文件夹大小,大于这个值,将从upstream服务器传
proxy_temp_file_write_size 64k;
}
}
这样在使用9000端口访问服务器的时候就会进行8080和8082的负载调用
Nginx 负载均衡策略
轮询(默认)
按照时间顺序逐一的分配到不同的服务器,如果后端服务器挂掉,会自动删除,待恢复自动添加上
权重(weight)
weight代表权重,默认为1,权重越大分配的请求越多,weight和访问比率成正比,用于后端服务器性能不均的情况
# 负载均衡
upstream myserver {
server 127.0.0.1:8080 weight=1;
server 127.0.0.1:8082 weight=2;
}
最少连接
使用最少连接的负载均衡,可以防止过多的请求都堆积到一台服务器上
# 负载均衡
upstream myserver {
least_conn;
server 127.0.0.1:8080;
server 127.0.0.1:8082;
}
ip_hash
每个请求按照访问的ip进行hash分配,使得每个访问者固定访问某一个服务器,可以解决session问题
# 负载均衡
upstream myserver {
ip_hash;
server 127.0.0.1:8080;
server 127.0.0.1:8082;
}
url_hash
按照访问的url进行hash分配,每一个url定向到同一个后端服务器
upstream的fail_timeout和max_fails参数是用来判断负载均衡upstream中的某个server是否失效,在fail_timeout的时间内,nginx与upstream中某个server的连接尝试失败了max_fails次,则nginx会认为该server已经失效,在接下来的fail_timeout时间内,nginx不再将请求分发给失效的server
# 负载均衡
upstream myserver {
hash $request_uri;
# 指定hash算法
hash_method crc32;
server 127.0.0.1:8080;
server 127.0.0.1:8082;
}
fair(第三方)
根据请求的响应时间来分配,哪个服务器响应的快分配给谁
# 负载均衡
upstream myserver {
fair;
server 127.0.0.1:8080;
server 127.0.0.1:8082;
}
https://zhhll.icu/2021/服务器/Nginx/7.配置负载均衡/
猜你喜欢
- 2024-10-09 程序员都应该懂的微服务容错与隔离:熔断保护、超时与重试原理
- 2024-10-09 Nginx为什么快到根本停不下来?(nginx解决什么问题)
- 2024-10-09 Nginx代理webSocket经常中断的解决方案,如何保持长连接
- 2024-09-09 怎么测试nginx反向代理(nginx反向代理配置参数)
- 2024-09-09 关于LNMP+Frp内网穿透环境下一个PHP程序运行超时的问题
- 2024-09-09 Nginx反向代理(nginx是干嘛用的)
- 2024-09-09 Nginx这么香,还不知道怎么学?看完这份Nginx笔记你能立马上手
- 2024-09-09 「每天一道面试题」Nginx 502错误原因和解决方法
- 2024-09-09 年轻人你不讲武德,Nginx之负载均衡演示
- 2024-09-09 应用程序加固Nginx篇(如何给应用加固)
你 发表评论:
欢迎- 最近发表
-
- Win11学院:如何在Windows 11上使用WSL安装Ubuntu
- linux移植(Linux移植freemodbus)
- 独家解读:Win10预览版9879为何无法识别硬盘
- 基于Linux系统的本地Yum源搭建与配置(ISO方式、RPM方式)
- Docker镜像瘦身(docker 减小镜像大小)
- 在linux上安装ollama(linux安装locale)
- 渗透测试系统Kali推出Docker镜像(kali linux渗透测试技术详解pdf)
- Linux环境中部署Harbor私有镜像仓库
- linux之间传文件命令之Rsync傻瓜式教程
- 解决ollama在linux中安装或升级时,通过国内镜像缩短安装时长
- 标签列表
-
- 下划线是什么 (87)
- 精美网站 (58)
- qq登录界面 (90)
- nginx 命令 (82)
- nginx .http (73)
- nginx lua (70)
- nginx 重定向 (68)
- Nginx超时 (65)
- nginx 监控 (57)
- odbc (59)
- rar密码破解工具 (62)
- annotation (71)
- 红黑树 (57)
- 智力题 (62)
- php空间申请 (61)
- 按键精灵 注册码 (69)
- 软件测试报告 (59)
- ntcreatefile (64)
- 闪动文字 (56)
- guid (66)
- abap (63)
- mpeg 2 (65)
- column (63)
- dreamweaver教程 (57)
- excel行列转换 (56)
本文暂时没有评论,来添加一个吧(●'◡'●)