一、Nginx实现负载均衡的4种常用方式为:轮询模式、IP哈希模式、权重模式、 最少连接
实现负载均衡需要在 http 模块中配置使用 upstream 模块定义后台的web server的池子,名为proxy-web,在池子中我们可以添加多台后台web server,其中状态检查、调度算法都是在池子中配置;然后在server模块中定义虚拟主机,但这个虚拟主机不指定自己的web目录站点,它将使用location匹配url然后转发到上面定义好的 web 池子中,最后根据调度策略再转发到后台web server 上。
http 块的原始配置如下:
http {include mime.types;default_type application/octet-stream;sendfile on;#tcp_nopush on;#keepalive_timeout 0;keepalive_timeout 65;#gzip on;server {listen 80;server_name localhost;#charset koi8-r;#access_log logs/host.access.log main;location / {root html;index index.html index.htm;}#error_page 404 /404.html;# redirect server error pages to the static page /50x.html#error_page 500 502 503 504 /50x.html;location = /50x.html {root html;}}
}
1、轮询模式(默认):按照后端服务器的顺序依次分发请求;
在 http 块 的配置如下:
upstream proxy_nginx1 {server 192.168.1.101:8080;server 192.168.1.102:8080;server 192.168.1.103:8080;}
2、权重模式:指定轮询几率,weight和访问比例成正比,用于后端服务器性能不均的情况;
upstream proxy_nginx2 {server 192.168.100.252:8081 weight=1;server 192.168.100.252:8082 weight=2;server 192.168.100.252:8083 weight=5;}
3、IP哈希模式:每个请求访问按访问 IP 的hash结果分配,这样每个访客固定访问一个后端服务器,可以解决session的问题;
upstream proxy_nginx3 {ip_hash;server 192.168.100.252:8081;server 192.168.100.252:8082;server 192.168.100.252:8083;}
4、最小连接;Nginx会将请求分配给活动连接数最少的服务器,以实现负载均衡
upstream proxy_nginx4 {least_conn;server 192.168.100.252:8081;server 192.168.100.252:8082;server 192.168.100.252:8083;
}
然后在location匹配对应的名称即可,以配置权重模式为例,在 http 块的配置如下:
# 代理转发
location /test {proxy_pass http://proxy_nginx2;
}
同理,如果是IP哈希模式则改为: proxy_pass http://proxy_nginx3;
二、路径匹配规则
多个 location 配置的情况下匹配顺序为:
首先匹配=,其次匹配 ^~,然后是按照文件顺序的正则匹配,最后是交给 / 通用匹配。当有匹配成功时,停止匹配 ,按当前匹配规则处理请求。
详细的配置规则可参考以下两篇文章
1、nginx怎么设置匹配路径 nginx 匹配规则
2、Nginx路径匹配规则小结
还有,禁止访问某个目录可做如下设置
location ^~ /path/ {deny all;
}