nginx反向代理配置如何去除字首

安全劍客發表於2021-01-30
使用Nginx做代理的時候,可以簡單的直接把請求原封不動的轉發給下一個服務。下面我們講講更多的用法

nginx反向代理配置如何去除字首nginx反向代理配置如何去除字首

使用Nginx做代理的時候,可以簡單的直接把請求原封不動的轉發給下一個服務。
比如,訪問abc.com/appv2/a/b.html, 要求轉發到localhost:8088/appv2/a/b.html
簡單配置如下:

upstream one {
        server localhost:8088 weight=5;
 }
server {
        listen 80;
        server_name abc.com;
        access_log "pipe:rollback /data/log/nginx/access.log interval=1d baknum=7 maxsize=1G" main;
        location / {
                proxy_set_header Host $host;
                proxy_set_header X-Real-IP $remote_addr;
                proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
                proxy_set_header X-NginX-Proxy true;
                proxy_pass 
        }
 }

即,設定  proxy_pass 即可。請求只會替換域名。但很多時候,我們需要根據url的字首轉發到不同的服務。設定proxy_pass請求只會替換域名,如果要根據不同的url字尾來訪問不同的服務,則需要透過如下方法.

方法一:加"/"
server {
    listen              8000;
    server_name         abc.com;
    access_log  "pipe:rollback /data/log/nginx/access.log interval=1d baknum=7 maxsize=1G"  main;
    location ^~/user/ {
        proxy_set_header Host $host;
        proxy_set_header  X-Real-IP        $remote_addr;
        proxy_set_header  X-Forwarded-For  $proxy_add_x_forwarded_for;
        proxy_set_header X-NginX-Proxy true;
        proxy_pass 
    }
    location ^~/order/ {
        proxy_set_header Host $host;
        proxy_set_header  X-Real-IP        $remote_addr;
        proxy_set_header  X-Forwarded-For  $proxy_add_x_forwarded_for;
        proxy_set_header X-NginX-Proxy true;
        proxy_pass 
    }
}

^~/user/表示匹配字首是 user的請求, proxy_pass的結尾有 /, 則會把 /user/*後面的路徑直接拼接到後面,即移除 user

方法二:rewrite
upstream user {
  server localhost:8089 weight=5;
}
upstream order {
  server localhost:8090 weight=5;
}
server {
    listen              80;
    server_name  abc.com;
    access_log  "pipe:rollback /data/log/nginx/access.log interval=1d baknum=7 maxsize=1G"  main;
    location ^~/user/ {
        proxy_set_header Host $host;
        proxy_set_header  X-Real-IP        $remote_addr;
        proxy_set_header  X-Forwarded-For  $proxy_add_x_forwarded_for;
        proxy_set_header X-NginX-Proxy true;
        rewrite ^/user/(.*)$ /$1 break;
        proxy_pass 
    }
    location ^~/order/ {
        proxy_set_header Host $host;
        proxy_set_header  X-Real-IP        $remote_addr;
        proxy_set_header  X-Forwarded-For  $proxy_add_x_forwarded_for;
        proxy_set_header X-NginX-Proxy true;
        rewrite ^/order/(.*)$ /$1 break;
        proxy_pass 
    }
}

proxy_pass結尾 /,  rewrite重寫了url。

關於rewrite
syntax: rewrite regex replacement [flag]
Default: —
Context: server, location, if

原文地址:

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/31559985/viewspace-2754667/,如需轉載,請註明出處,否則將追究法律責任。

相關文章