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

相关推荐
Hygge-star6 小时前
【数据结构】二分查找5.12
java·数据结构·程序人生·算法·学习方法
全栈派森14 小时前
云存储最佳实践
后端·python·程序人生·flask
测试界萧萧1 天前
15:00开始面试,15:06就出来了,问的问题有点变态。。。
自动化测试·软件测试·功能测试·程序人生·面试·职场和发展
CIb0la2 天前
数据可视化
程序人生·算法·信息可视化
lkbhua莱克瓦242 天前
用C语言实现了——一个基于顺序表的插入排序演示系统
c语言·开发语言·数据结构·程序人生·github·排序算法·交互
航Hang*6 天前
C PRIMER PLUS——第6-2节:二维数组与多维数组
c语言·开发语言·经验分享·程序人生·算法·学习方法·visual studio
大刘讲IT6 天前
轻量化工业互联网平台在中小制造企业的垂直应用实践:架构、集成、数据价值与选型策略
大数据·学习·程序人生·架构·数据挖掘·能源·制造
CIb0la11 天前
同质化的旅游内核
程序人生·生活·旅游
柏木乃一13 天前
平衡二叉搜索树模拟实现1-------AVL树(插入,删除,查找)
c++·学习·程序人生·算法·二叉搜索树·avl树·平衡二叉搜索树
自由鬼16 天前
深海科技服务博客简介
运维·网络·人工智能·程序人生·安全威胁分析·个人开发·数据安全