server的匹配邏輯
nginx在決定請求由哪個server區塊執行時,主要關注的是server區塊中的listen和server_name兩個欄位
listen指令
listen欄位定義server回應的ip和連接埠,如果沒有明確配置listen欄位,預設監聽0.0.0.0:80(root)或0.0.0.0:8080 (非root)
listen可以被設定為:
一個ip和連接埠的組合
一個單獨的ip ,預設監聽80埠
一個單獨的連接埠,預設監聽所有的ip介面
# server block 1server { listen 192.168.0.1; server_name other.com ... } # server block 2server { listen 80; server_name example.com ... }
server_name指令
如果根據listen指令無法得到最佳匹配,將會開始解析server_name指令.nginx會檢查請求中的"host"頭,這個值包含了客戶端實際試圖請求的網域或ip位址.nginx會根據這個值去匹配server_name指令,符合規則如下:
server { listen 80; server_name www.domain.com; ... }(2)以*通配符開始的字串:
server { listen 80; server_name *.domain.com; ... }(3)以*通配符結束的字串:
server { listen 80; server_name www.*; ... }(4)符合正規表示式:
server { listen 80; server_name ~^(?.+)\.domain\.com$; ... }(5)如果以上都沒有匹配,則使用default_server.如果沒有指定default_server,則會選擇第一個可用的server.我們可以指定對於沒有匹配的host值時,返回錯誤到客戶端.可以用來防止別人把垃圾流量轉到你的網站。
server { listen 80 default_server; server_name _; return 444; }透過回傳444這個nginx的非標準錯誤碼讓nginx斷開與瀏覽器的連線
location的符合邏輯
location語法解析
location optional_modifier location_match { ... }其中可用的modifier修飾符如下 #判定規則1、nginx首先檢查基於前綴的location匹配(即不包含正規表示式的匹配)2、如果有使用=修飾符的location塊與請求的url完全匹配,則立刻使用該location響應請求 #3、如果沒有找到帶有=修飾符的location塊匹配,則會繼續計算非精確前綴,根據給定的uri找到最長匹配前綴,然後進行如下處理:(1)如果最長的匹配location帶有^~修飾符,nginx立刻使用該location回應請求(2)如果最長的匹配location不帶有^~修飾符,nginx會將該匹配暫時存起來,然後繼續後續匹配4、在確定並儲存最長匹配的前綴location塊後,nginx繼續檢查正則表達式匹配location(區分大小寫/不區分大小寫).如果存在正則表達式滿足要求的匹配,則會選擇與請求的uri匹配的第一個正則表達式的location來相應請求#5、如果沒有找到與請求的uri匹配的正則表達式location,則使用之前儲存的最長前綴location回應請求
補充
通常情況下,一旦選擇使用某一個location回應請求,那麼請求將會在該location內部進行處理,而與其他location無關.但是location中某些指令會觸發新的location匹配,例如:
(1)try_files
(2)rewrite
(3)error_page
以上是Nginx中Server和Location的匹配邏輯是什麼的詳細內容。更多資訊請關注PHP中文網其他相關文章!