Nginx配置负载均衡
使用nginx来配置负载均衡也是比较简单的
首先在http块中配置虚拟域名所对应的地址
1 2 3 4 5
| # 负载均衡 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块中配置监听
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49
| 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和访问比率成正比,用于后端服务器性能不均的情况
1 2 3 4 5
| # 负载均衡 upstream myserver { server 127.0.0.1:8080 weight=1; server 127.0.0.1:8082 weight=2; }
|
最少连接
使用最少连接的负载均衡,可以防止过多的请求都堆积到一台服务器上
1 2 3 4 5 6
| # 负载均衡 upstream myserver { least_conn; server 127.0.0.1:8080; server 127.0.0.1:8082; }
|
ip_hash
每个请求按照访问的ip进行hash分配,使得每个访问者固定访问某一个服务器,可以解决session问题
1 2 3 4 5 6
| # 负载均衡 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
1 2 3 4 5 6 7 8
| # 负载均衡 upstream myserver { hash $request_uri; # 指定hash算法 hash_method crc32; server 127.0.0.1:8080; server 127.0.0.1:8082; }
|
fair(第三方)
根据请求的响应时间来分配,哪个服务器响应的快分配给谁
1 2 3 4 5 6
| # 负载均衡 upstream myserver { fair; server 127.0.0.1:8080; server 127.0.0.1:8082; }
|