2 回答

TA貢獻2051條經(jīng)驗 獲得超10個贊
nginx不支持非正則,所以,沒有辦法一條實現(xiàn)這個你這個功能,只能“曲線救國”,要麻煩點,多建虛機:
還有就是瀏覽器#號不會被傳入到服務(wù)端,所以,你要替換掉這個符號,我這里用的是@
set $ip 192.168.0.2;
if ($request_uri ~* /@/(.*)+) {
set $ip 192.168.0.1;
}
location / {
proxy_pass http: //$ip;
}

TA貢獻1797條經(jīng)驗 獲得超6個贊
Location語法語法:location [=|~|~*|^~] /uri/ { … }
= --> 開頭表示精確匹配
^~ --> 開頭表示uri以某個常規(guī)字符串開頭,理解為匹配url路徑即可。
nginx不對url做編碼,因此請求為/static/20%/aa,可以被規(guī)則^~ /static/ /aa匹配到(注意是空格)。
~ --> 開頭表示區(qū)分大小寫的正則匹配
~* --> 開頭表示不區(qū)分大小寫的正則匹配
!~和!~* --> 分別為區(qū)分大小寫不匹配及不區(qū)分大小寫不匹配的正則
/ --> 通用匹配,任何請求都會匹配到。
多個location配置的情況下匹配順序為:
首先匹配=,其次匹配^~, 其次是按文件中順序的正則匹配,最后是交給 / 通用匹配。當有匹配成功時候,停止匹配,按當前匹配規(guī)則處理請求。
例子,有如下匹配規(guī)則:
location = / {
#http://localhost/ 訪問根目錄/
#規(guī)則A
}
location = /login {
#http://localhost/login
#規(guī)則B
}
location ^~ /static/ {
#http://localhost/static/a.html
#http://localhost/static/c.png 則優(yōu)先匹配到 規(guī)則C
#規(guī)則C
}
#http://localhost/a.gif, http://localhost/b.jpg 將匹配規(guī)則D和規(guī)則E,但是規(guī)則D順序優(yōu)先,規(guī)則E不起作用,
location ~ \.(gif|jpg|png|js|css)$ {
#規(guī)則D
}
location ~* \.png$ {
#http://localhost/a.PNG 則匹配規(guī)則E,而不會匹配規(guī)則D,因為規(guī)則E不區(qū)分大小寫。
#規(guī)則E
}
http://localhost/a.xhtml 不會匹配規(guī)則F和規(guī)則G,
http://localhost/a.XHTML 不會匹配規(guī)則G,因為不區(qū)分大小寫。
規(guī)則F,規(guī)則G屬于排除法,符合匹配規(guī)則但是不會匹配到,所以想想看實際應用中哪里會用到。
location !~ \.xhtml$ {
#規(guī)則F
}
location !~* \.xhtml$ {
#規(guī)則G
}
訪問http://localhost/category/id/1111 最終匹配到規(guī)則H,因為以上規(guī)則都不匹配,這個時候應該是nginx轉(zhuǎn)發(fā)請求給后端應用服務(wù)器,
比如FastCGI(php),tomcat(jsp),nginx作為方向代理服務(wù)器存在。
location / {
#http://localhost/register
#規(guī)則H
}
所以實際使用中,個人覺得至少有三個匹配規(guī)則定義,如下:
#直接匹配網(wǎng)站根,通過域名訪問網(wǎng)站首頁比較頻繁,使用這個會加速處理,官網(wǎng)如是說。
#這里是直接轉(zhuǎn)發(fā)給后端應用服務(wù)器了,也可以是一個靜態(tài)首頁
# 第一個必選規(guī)則location = / {
proxy_pass http://tomcat:8080/index
}
# 第二個必選規(guī)則是處理靜態(tài)文件請求,這是nginx作為http服務(wù)器的強項
# 有兩種配置模式,目錄匹配或后綴匹配,任選其一或搭配使用location ^~ /static/ {
root /webroot/static/;
}
location ~* \.(gif|jpg|jpeg|png|css|js|ico)$ {
root /webroot/res/;
}
#第三個規(guī)則就是通用規(guī)則,用來轉(zhuǎn)發(fā)動態(tài)請求到后端應用服務(wù)器
#非靜態(tài)文件請求就默認是動態(tài)請求,自己根據(jù)實際把握
#畢竟目前的一些框架的流行,帶.php,.jsp后綴的情況很少了location / {
proxy_pass http://tomcat:8080/
}
對于以上基礎(chǔ)推薦配置,有一個補充,就是關(guān)于轉(zhuǎn)發(fā)有一點需要注意。例如下面配置,對一個目錄轉(zhuǎn)發(fā):
location ^~ /outer/ {
#case A: url最后以/結(jié)尾 proxy_pass http://tomcat:8080/
#case B: url最后沒有/ #proxy_pass http://tomcat:8080 }
關(guān)鍵在于最后的/,訪問localhost/outer/in.html,其中case A會轉(zhuǎn)發(fā)到tomcat:8080/in.html, 而case B會轉(zhuǎn)發(fā)到tomcat:8080/outer/in.html,所以務(wù)必注意了。
添加回答
舉報