Nginx篇之常见的配置跳转的方式

一、介绍
现如今,随着应用服务的增多,服务可能部署在不同的服务器上。
这些服务有可能存在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;
   }
}
  • 2
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
您好!关于Nginx反向代理不跳转的问题,您可以尝试以下方法来解决: 1. 检Nginx配置文件:确认您的Nginx配置文件中是否正确配置了反向代理。您可以通过Nginx配置文件(通常位于/etc/nginx/nginx.conf或者/etc/nginx/conf.d/目录下)来确认反向代理的配置是否正确。 2. 检代理目标的IP地址和端口:确保您配置的代理目标IP地址和端口是正确的。您可以通过ping或telnet等工具来检代理目标是否可达。 3. 检代理目标的协议:确认您的代理目标服务器是通过HTTP还是HTTPS协议进行通信。如果代理目标使用HTTPS,请确保您的Nginx配置文件中启用了SSL/TLS相关设置。 4. 检代理头部设置:有时候,代理请求可能会由于未正确设置请求头部而导致跳转。您可以尝试在Nginx配置文件中添加以下指令来禁用或修改请求头部: proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; 5. 检其他可能的因素:有时候,代理目标服务器的响应头部也可能会引起跳转。您可以使用浏览器开发者工具或curl命令来看代理目标服务器的响应头部,以确定是否有需要调整的设置。 请注意,以上的解决方法只是一些常见的排步骤,具体的解决方案可能因您的具体情况而异。如果问题仍然存在,建议您提供更多详细信息,以便我能够给出更准确的帮助。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值