Nginx配置负载均衡

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.配置负载均衡/

本文由mdnice多平台发布

相关推荐
晓衣19 小时前
2025“獬豸杯”全国电子数据取证竞赛-k8s服务器取证wp
服务器·经验分享·程序人生·网络安全·容器·kubernetes·学习方法
JosieBook1 天前
【程序人生】有梦想就能了不起,就怕你没梦想
程序人生·职场和发展
利以檀本人(梦泽不忙)4 天前
#T1359. 围成面积
c++·程序人生·算法
jingling5554 天前
【高级】系统架构师 | 信息系统战略规划、EAI 与新技术
程序人生·职场和发展·系统架构·学习方法·程序员创富
序属秋秋秋4 天前
我的创作纪念日——《惊变365天》
经验分享·学习·程序人生·纪念日·生活·大学生
蓑衣客VS索尼克5 天前
第三章:生活重构:当程序员不再只是“码农“
学习·程序人生·重构·生活
武子康5 天前
66AI-调查研究-68-具身智能 应用全景:家庭、工业、医疗、交通到虚拟交互的未来趋势
人工智能·程序人生·ai·职场和发展·交互·个人开发·具身智能
swanwei5 天前
技术人员突围之路(15年技术管理经验总结)之十
学习·程序人生·生活·求职招聘·交友
武子康6 天前
AI-调查研究-67-具身智能 核心技术构成全解析:感知、决策、学习与交互的闭环系统
人工智能·科技·学习·程序人生·ai·职场和发展·职场发展
郝学胜-神的一滴7 天前
Pomian语言处理器研发笔记(二):使用组合模式定义表示程序结构的语法树
开发语言·c++·笔记·程序人生·决策树·设计模式·组合模式