一、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;
}
标签:负载,匹配,192.168,server,Nginx,100.252,proxy,location
From: https://blog.csdn.net/qq_39964887/article/details/140053991