語法規則: location [=|~|~*|^~] /uri/
=開頭表示精確匹配
^~開頭表示uri以某個常規字串開頭,理解為匹配url路徑即可。nginx不對url做編碼,因此請求為/static/20%/aa,可以被規則^~ /static/ /aa匹配到(注意是空格)(20%表示空格)。
~ 開頭表示區分大小寫的正則匹配
~* 開頭表示不區分大小寫的正則匹配
!~和!~*分別為區分大小寫不匹配及不區分大小寫不匹配 的正則
/ 通用匹配,任何請求都會匹配到。
多個location配置的情況下匹配順序為
首先匹配 =,其次匹配^~, 其次是按檔案中順序的正則匹配,最後是交給 / 通用匹配。當有匹配成功時候,停止匹配,按當前匹配規則處理請求。
那麼產生的效果如下:
訪問根目錄/, 比如http://localhost/ 將匹配規則a
訪問 http://localhost/login 將匹配規則b,http://localhost/register 則匹配規則h
訪問 http://localhost/static/a.html 將匹配規則c
訪問 http://localhost/a.gif, http://localhost/b.jpg 將匹配規則d和規則e,但是規則d順序優先,規則e不起作用,而 http://localhost/static/c.png 則優先匹配到 規則c
訪問 http://localhost/a.png 則匹配規則e, 而不會匹配規則d,因為規則e不區分大小寫。
訪問 http://localhost/a.xhtml 不會匹配規則f和規則g,http://localhost/a.xhtml不會匹配規則g,因為不區分大小寫。規則f,規則g屬於排除法,符合匹配規則但是不會匹配到,所以想想看實際應用中**會用到。
訪問 http://localhost/category/id/1111 則最終匹配到規則h,因為以上規則都不匹配,這個時候應該是nginx**請求給後端應用伺服器,比如fastcgi(php),tomcat(jsp),nginx作為方向**伺服器存在。
所以實際使用中,通常至少有三個匹配規則定義,如下:
#直接匹配**根,通過網域名稱訪問**首頁比較頻繁,使用這個會加速處理,官網如是說。#這裡是直接**給後端應用伺服器了,也可以是乙個靜態首頁
# 第乙個必選規則
location = /
# 第二個必選規則是處理靜態檔案請求,這是nginx作為http伺服器的強項
# 有兩種配置模式,目錄匹配或字尾匹配,任選其一或搭配使用
#第三個規則就是通用規則,用來**動態請求到後端應用伺服器
#非靜態檔案請求就預設是動態請求,自己根據實際把握
#畢竟目前的一些框架的流行,帶.php,.jsp字尾的情況很少了
location /
參考:
Nginx學習(二) location的相關配置
從這一篇部落格開始,正式介紹nginx的一些使用,這一篇會總結一下虛擬主機和location的相關配置。參考過很多部落格的內容,但是關於nginx中location的配置總結的很全的並沒有多少,這裡根據官網來進行簡單總結。所謂的虛擬主機,其實就是在一套伺服器上構建多個主機,這些主機是虛擬出來的,這個...
nginx的location配置詳解
語法規則 location uri 開頭表示精確匹配 開頭表示uri以某個常規字串開頭,理解為匹配 url路徑即可。nginx不對url做編碼,因此請求為 static 20 aa,可以被規則 static aa匹配到 注意是空格 開頭表示區分大小寫的正則匹配 開頭表示不區分大小寫的正則匹配 和 分...
nginx的location配置詳解
語法規則 location uri 開頭表示精確匹配 開頭表示uri以某個常規字串開頭,理解為匹配 url路徑即可。nginx不對url做編碼,因此請求為 static 20 aa,可以被規則 static aa匹配到 注意是空格 開頭表示區分大小寫的正則匹配 開頭表示不區分大小寫的正則匹配 和 分...