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多平台发布

相关推荐
电星托马斯16 小时前
Linux系统CentOS 6.3安装图文详解
linux·运维·服务器·程序人生·centos
电星托马斯1 天前
C++中顺序容器vector、list和deque的使用方法
linux·c语言·c++·windows·笔记·学习·程序人生
软件测试曦曦2 天前
如何使用Python自动化测试工具Selenium进行网页自动化?
自动化测试·软件测试·python·功能测试·测试工具·程序人生·自动化
电气外传2 天前
Share02-小小脚本大大能量
程序人生·自动化
测试界柠檬2 天前
15:00开始面试,15:08就出来了,问的问题有点变态。。。
自动化测试·软件测试·功能测试·程序人生·面试·职场和发展
Tiger Z2 天前
R 语言科研绘图 --- 韦恩图-汇总
开发语言·程序人生·r语言·贴图
Gerry_Liang4 天前
如何免费阅读Medium文章?
程序人生·学习方法
Foyo Designer5 天前
【 <二> 丹方改良:Spring 时代的 JavaWeb】之 Spring Boot 中的消息队列:使用 RabbitMQ 实现异步处
java·spring boot·程序人生·spring·职场和发展·rabbitmq·java-rabbitmq
云狐创意5 天前
小豆包api:gpt-4o模型api已接入,出图更稳定
人工智能·程序人生
程序猿chen6 天前
云原生四重涅槃·破镜篇:混沌工程证道心,九阳真火锻金身
java·开发语言·git·后端·python·程序人生·云原生