一、介绍
现如今,随着应用服务的增多,服务可能部署在不同的服务器上。
这些服务有可能存在IP、端口Port、请求的ContextPath等一样的情况。
当我们正式线上的业务量不断扩增的时候,随着用户使用量的不断增多,可能会导致ugc【User Generated Content 用户内容生成】的访问请求量过高,外网带宽打满,此时由于ugc请求过多,但是response响应过慢,导致生成的log占用资源过多,形成堵塞。
所以一般遇到这种情况,通常可通过给nginx配置相应的跳转或访问return,来做流量限制。
常见的跳转方式如下:
二、常见的跳转方式
1、根据不同域名判断跳转不同服务
就是根据在nginx.conf配置的server_name与域名或者(或者IP)匹配跳转不同的服务。
#1、当客户端访问www.main.com,监听端口号为80,直接跳转到data/www目录下文件
server {
listen 80;
server_name www.main.com;
location / {
root data/www;
index index.html index.htm;
}
}
#2、当客户端访问abc.domain.com,监听端口号为80,直接跳转到data/bbs目录下文件
server {
listen 80;
server_name abc.domain.com;
location / {
root data/bbs;
index index.html index.htm;
}
}
2、根据不同端口判断跳转不同服务
即:就是根据在nginx.conf配置的listen指令匹配跳转不同的服务。
#1、当客户端访问www.main.com,监听端口号为8081,直接跳转到data/www目录下文件
server {
listen 8081;
server_name www.main.com;
location / {
root data/www;
index index.html index.htm;
}
}
#2、当客户端访问www.main.com,监听端口号为8082,直接跳转到data/bbs目录下文件
server {
listen 8082;
server_name www.main.com;
location / {
root data/bbs;
index index.html index.htm;
}
}
3、根据链接的ContextPath不同跳转不同的服务器
主要根据每个应用服务器的ContextPath的普通,匹配跳转到不同的服务器。
#服务创建监听的端口号
server {
#监听的端口号
listen 80;
#服务名称
server_name www.main.com;
# 1、匹配项目名称为bbs开头
location /bbs/ {
# 配置反向代理
proxy_pass http://192.168.1.188:8081/;
index index.html index.htm;
}
# 2、匹配项目名称为blog开头
location /blog/ {
# 配置反向代理
proxy_pass http://192.168.1.188:8082/;
index index.html index.htm;
}
}