nginx location配置小結

        前幾天工作時有需求配置nginx location,之前看過的相關知識都記不太清楚了,特別是多個location時的執行順序問題。特此寫個這塊兒的小結來複習一下有關知識點。

 

語法規則: location [ = | ~ | ~* | ^~ ] pattern { … }

[=|~|~*|^~] 被稱作 location modifier ,這會定義 Nginx 如何去匹配其後的 pattern ,以及該 pattern 的最基本的屬性(簡單字符串或正則表達式)

多個location配置按匹配順序排列如下:

       location = /uri    =開頭表示精確匹配,只有完全匹配上才能生效。

  location ^~ /uri     ^~ 開頭表示uri以某個常規字符串開頭,理解爲匹配 url路徑即可。nginx不對url做編碼,因此請求                                                      爲/static/20%/aa,可以被規則^~ /static/ /aa匹配到(注意是空格)

  location ~ pattern   ~開頭表示區分大小寫的正則匹配, pattern 須是正則表達式。

  location ~* pattern  ~*開頭表示不區分大小寫的正則匹配, pattern 須是正則表達式。

  location /uri     不帶任何修飾符,也表示前綴匹配,但是在正則匹配之後。

  location /      通用匹配,任何未匹配到其它location的請求都會匹配到 /,相當於switch中的default。 

例如:

server
{ 
        listen  8081;
        server_name     localhost;

        location = / {
           #規則A  = 開頭表示精確匹配
           return 601;
        }

        location = /login {
           #規則B
           return 602;
        }

        location ^~ /static/ {
           #規則C  ^~ 開頭表示uri以某個常規字符串開頭,理解爲匹配 url路徑即可
           return 603;
        }

        location ~ \.(jpg|png|php|py)$ {
           #規則D  ~開頭表示區分大小寫的正則匹配(注意:~後面跟的是正則表達式)
           return 604;
        }

        location ~* \.png$ {
           #規則E  ~*開頭表示不區分大小寫的正則匹配
           return 605;
        }

        location / {
           #規則F  通用匹配,任何未匹配到其它location的請求都會匹配到 /,相當於switch中的default
           return 666;
        }
}

訪問根目錄 / (注意前面的=,區別於規則F), 比如http://localhost:8081/ 將匹配規則A
訪問 http://localhost:8081/login 將匹配規則B,http://localhost/register 則匹配規則F(未匹配到其它location的請求都會匹配到F)
訪問 http://localhost:8081/static/a.html 將匹配規則C
訪問 http://localhost:8081/a.php, http://localhost/b.png 將匹配規則D和規則E,但是規則D順序優先,規則E不起作用,而 http://localhost:8081/static/c.png 則優先匹配到 規則C
訪問 http://localhost:8081/a.PNG 則匹配規則E, 而不會匹配規則D,因爲規則E不區分大小寫。
訪問 http://localhost:8081/category/id/1111 則最終匹配到規則F,因爲以上規則都不匹配

實際使用中,通常至少有三個匹配規則定義,如下:

#直接匹配網站根,通過域名訪問網站首頁比較頻繁,使用這個會加速處理,官網如是說。
#這裏是直接轉發給後端應用服務器了,也可以是一個靜態首頁
# 第一個必選規則
location = / {
    proxy_pass http://localhost:8081/index
}
 
# 第二個必選規則是處理靜態文件請求,這是nginx作爲http服務器的強項
# 有兩種配置模式,目錄匹配或後綴匹配,任選其一或搭配使用
location ^~ /static/ {
    root /webroot/static/;
}
location ~* \.(gif|jpg|png|css|js)$ {
    root /webroot/res/;
}

#第三個規則就是通用規則,用來轉發動態請求到後端應用服務器
#非靜態文件請求就默認是動態請求,自己根據實際把握
#目前的一些框架的流行,帶.php 後綴的情況很少了
location / {
    proxy_pass http://localhost:8081/
}

nginx的rewrite語法介紹:

在server塊下,會優先執行rewrite部分,然後纔會去匹配location塊,

location中的rewrite,不寫last(使用last會對server標籤重新發起請求)和break(用break語句停止rewrite檢查 ),那麼流程就是依次執行這些rewrite。

如果location中rewrite後是對靜態資源的請求,不需要再進行其他匹配,一般要使用break或不寫,直接使用當前location中的數據源,完成本次請求 
如果location中rewrite後還需要進行其他處理,如動態fastcgi請求(.php  .jsp)等,需要用last繼續發起新的請求 

1. rewrite break

  url重寫後,直接使用當前資源,不再執行location裏餘下的語句,完成本次請求,地址欄url不變 

2. rewrite last

  url重寫後,馬上發起一個新的請求,再次進入server塊,重試location匹配,超過10次匹配不到報500錯誤,地址欄url不變 

3. rewrite redirect

  返回302臨時重定向,地址欄顯示重定向後的url

4. rewrite permanent

  返回301永久重定向, 地址欄顯示重定向後的url

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章