一、介绍
现如今,随着应用服务的增多,服务可能部署在不同的服务器上。
这些服务有可能存在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;
   }
}
Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐