【轉】Nginx服務器的反向代理proxy_pass配置方法講解

【轉】Nginx服務器的反向代理proxy_pass配置方法講解

轉自:http://www.jb51.net/article/78746.htmhtml

就普通的反向代理來說
Nginx的配置仍是比較簡單的,如:nginx

location ~ /* 
{
proxy_pass http://127.0.0.1:8008;
}

或者能夠服務器

location /
{
proxy_pass http://127.0.0.1:8008;
}

Apache2的反向代理的配置是:測試

ProxyPass /ysz/ http://localhost:8080/

然而,若是要配置一個相對複雜的反向代理
Nginx相對Apache2就要麻煩一些了
好比,將url中以/wap/開頭的請求轉發到後臺對應的某臺server上
能夠再Nginx裏設置一個變量,來臨時保存/wap/後面的路徑信息url

location ^~ /wap/
{
if ($request_uri ~ /wap/(\d+)/(.+))
{
set $bucketid $1;
set $params $2;
}
proxy_pass http://mx$bucketid.test.com:6601/$params;
}

也能夠首先rewrite一下,而後再代理:.net

location ^~ /wap/{
rewrite /wap/(\d+)/(.+) /$2?$args break;
proxy_pass http://mx$1.test.com:6601;
}

或者代理

location ~* /wap/(\d+)/(.+)
{
proxy_pass http://mx$1.test.com:6601/$2?$args;
}

注意上面最後的?$args,代表把原始url最後的get參數也給代理到後臺
若是在proxy_pass中使用了變量(無論是主機名變量$1或後面的$2變量),則必須得加這段代碼
但若是pass_proxy後沒用任何變量,則不須要加,它默認會把全部的url都給代理到後臺,如:日誌

location ~* /wap/(\d+)/(.+)
{
proxy_pass http://mx.test.com:6601;
}

而Apache2相對就簡單多了:code

ProxyPassMatch ^/wap/(.*)$  http://192.168.132.147/$1
 
if ($host ~* www.(.*)){
      set $host_without_www $1;
      rewrite (.*)$ http://$host_without_www/www$1;
    }

url的/問題
在nginx中配置proxy_pass時,當在後面的url加上了/,至關因而絕對根路徑,則nginx不會把location中匹配的路徑部分代理走;若是沒有/,則會把匹配的路徑部分也給代理走。
 
下面四種狀況分別用http://192.168.1.4/proxy/test.html 進行訪問。
第一種:server

location /proxy/ {
     proxy_pass http://127.0.0.1:81/;
}

會被代理到http://127.0.0.1:81/test.html 這個url
 
第二咱(相對於第一種,最後少一個 /)

location /proxy/ {
     proxy_pass http://127.0.0.1:81;
}

會被代理到http://127.0.0.1:81/proxy/test.html 這個url
 
第三種:

location /proxy/ {
     proxy_pass http://127.0.0.1:81/ftlynx/;
}

會被代理到http://127.0.0.1:81/ftlynx/test.html 這個url。
 
第四種狀況(相對於第三種,最後少一個 / ):

location /proxy/ {
     proxy_pass http://127.0.0.1:81/ftlynx;
}

會被代理到http://127.0.0.1:81/ftlynxtest.html 這個url 上面的結果都是本人結合日誌文件測試過的。從結果能夠看出,應該說分爲兩種狀況才正確。即http://127.0.0.1:81 (上面的第二種) 這種和 http://127.0.0.1:81/.... (上面的第1,3,4種) 這種。

相關文章
相關標籤/搜索