Nginx负载均衡
单机实战
nginx配置7层协议
/etc/nginx/conf.d/proxy.conf中
upstream mytest1 {
server 192.168.122.110:80; # 设置负载均衡
server 192.168.122.111:80;
server 192.168.122.112:80;
server 192.168.122.113:80;
}
server {
listen 80;
server_name www.proxy.com;
root /usr/share/nginx/app1;
access_log /var/log/www.proxy.log main;
error_log
/var/log/www.proxy.error.log;
location / {
proxy_pass http://mytest1; # 请求转向 代理服务器列表(我代理了谁)
proxy_set_header Host $http_host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_set_header X-NginX-Proxy true;
proxy_connect_timeout 30; #
proxy_send_timeout 60;
proxy_read_timeout 60;
proxy_buffering on;
proxy_buffer_size 32k;
proxy_buffers 4 128k;
proxy_busy_buffers_size 256k;
proxy_max_temp_file_size 256k;
index index.html;
}
}
/etc/nginx/conf.d/app1.conf 服务端添加配置
server {
listen 192.168.122.110:80; # 虚拟主机
server_name www.app1.com;
root /usr/share/nginx/app1;
access_log /var/log/app1.com.log main;
error_log
/var/log/app1.com.error.log;
set_real_ip_from 10.0.122.156; ##谁代理了我
location / {
index index.html;
}
}
其他提供服务修改对应ip地址即可
负载均衡算法
A、 轮询(默认) :每个请求按时间顺序逐一分配到不同的后端服务器;
B、 ip_hash :每个请求按访问IP的hash结果分配,同一个IP客户端固定访问一个后端服务器。可以保证
来自同一ip的请求被打到固定的机器上,可以解决session问题。
C、 url_hash :按访问url的hash结果来分配请求,使每个url定向到同一个后端服务器。后台服务器为
缓存的时候效率。
D、 fair :这是比上面两个更加智能的负载均衡算法。此种算法可以依据页面大小和加载时间长短智能
地进行负载均衡,也就是根据后端服务器的响应时间来分配请求,响应时间短的优先分配。 Nginx 本身
是不支持 fair 的,如果需要使用这种调度算法,必须下载Nginx的 upstream_fair 模块。
热备
服务器处理请求的顺序:AAAAAA突然A挂啦,BBBBBBBBBBBBBB.....
upstream myweb {
server 172.17.14.2:8080;
server 172.17.14.3:8080 backup; #热备
}
轮询
服务器处理请求的顺序:ABABABABAB
upstream myweb {
server 172.17.14.2:8080;
server 172.17.14.3:8080;
}
加权轮询
下面服务器的请求顺序为:ABBABBABBABBABB....默认为1
upstream myweb {
server 172.17.14.2:8080 weight=1;
server 172.17.14.3:8080 weight=2;
}
ip_hash
nginx会让相同的客户端ip请求相同的服务器。
upstream myweb {
server 172.17.14.2:8080;
server 172.17.14.3:8080;
ip_hash;
}
nginx负载均衡配置状态参数
down,表示当前的server暂时不参与负载均衡。
backup,预留的备份机器。当其他所有的非backup机器出现故障或者忙的时候,才会请求
backup机器,因此这台机器的压力最轻。
max_fails,允许请求失败的次数,默认为1。当超过最大次数时,返回proxy_next_upstream 模
块定义的错误。
fail_timeout,在经历了max_fails次失败后,暂停服务的时间。max_fails可以和fail_timeout一起
使用。
upstream myweb {
server 172.17.14.2:8080 weight=2 max_fails=2 fail_timeout=2;
server 172.17.14.3:8080 weight=1 max_fails=2 fail_timeout=1;
}
nginx配置4层协议方法(扩展)
/etc/nginx/nginx.conf
向该文件nginx.conf写入,stream与http同级
stream {
upstream mytest1 {
server 192.168.122.110:80;
server 192.168.122.111:80;
}
server {
listen 10.0.122.156:8888;
proxy_connect_timeout 10s;
proxy_timeout 30s;
proxy_pass mytest1; # 定义的负载均衡服务器列表
}
upstream mytest2 {
server 192.168.122.112:80;
server 192.168.122.113:80;
}
server {
listen 10.0.122.156:8989;
proxy_connect_timeout 10s;
proxy_timeout 30s;
proxy_pass mytest2;
}
}
负载均衡
proxy_connect_timeout 1; #nginx服务器与被代理的服务器建立连接的超时时间,默认60秒
proxy_read_timeout 1; #nginx服务器想被代理服务器组发出read请求后,等待响应的超时间,默认为
60秒。
proxy_send_timeout 1; #nginx服务器想被代理服务器组发出write请求后,等待响应的超时间,默认
为60秒。
proxy_ignore_client_abort on; #客户端断网时,nginx服务器是否终端对被代理服务器的请求。默
认为off。
proxy_next_upstream timeout; #反向代理upstream中设置的服务器组,出现故障时,被代理服务
器返回的状态值。
error|timeout|invalid_header|http_500|http_502|http_503|http_504|http_404|off