首頁  >  文章  >  運維  >  nginx多location怎麼配置

nginx多location怎麼配置

王林
王林轉載
2023-05-17 22:25:452601瀏覽

前言

nginx server下配置多個location根據路徑匹的不同做不同的處理。

nginx常用正規表示式

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

  • #= 開頭表示:精確比對。

  • ^~ 開頭表示:區分大小寫以什麼開頭。

  • ~ 開頭表示:區分大小寫的正規匹配。

  • ~* 開頭表示:不區分大小寫的正規匹配。

  • !~ 和!~*分別表示:區分大小寫 不符 及不區分大小寫 不符的正規匹配。

  • / 表示:通用匹配,任何請求都會匹配到。

多個location配置的情況下匹配順序為(未驗證):

首先匹配=,其次是匹配^~ , 其次是按文件中順序的正規匹配,最後是交給/ 通用匹配。當有匹配成功時候,停止匹配,並按當前匹配規則處理請求。

實測

server {
    listen       80;
    listen  [::]:80;
    server_name  location.test.com;

    access_log  /var/log/nginx/location.host.access.log  main;

    #*********************注意多个location通常按精确的放前面,模糊大范围的放后面,nginx先找= ******************************
    location = /login.html {#精确匹配 /login
	root /usr/share/nginx/html/test-equal;#请求/login.html相当于寻找资源/usr/share/nginx/html/test-equal/login.html
    }
    location ^~ /prefix/ {#区分大小写且以/prefix/开头
	root /usr/share/nginx/html/test-prefix;#root代表根目录,请求/prefix/prefix.html相当于寻找资源/usr/share/nginx/html/test-prefix/prefix/prefix.html 
    }
    location ~ \.(png|jpg)$ {#不区分大小写且以.png或.jpg结尾
	root /usr/share/nginx/html/test-suffix;#请求/suffix/a.png相当于寻找资源/usr/share/nginx/html/test-suffix/suffix/a.png
    }
    location ^~ /jd/ {# 区分大小写且以/jd/开头
	proxy_pass https://www.jd.com/;#proxy_pass  此处的url以/结尾,则nginx会取掉location部分再转发,例如,请求/jd/电器?name=1 则会转发到https://www.jd.com/电器?name=1
    }
    location ^~ /s {# /会匹配到所有的
	proxy_pass https://www.baidu.com;#proxy_pass  此处的url没有以/结尾,则匹配到的地址全部拼接到代理后的地址,例如,请求/s?name=1 则会转发到https://www.baidu.com/s?name=1
    }
    location  / {# 会返回index.html
	root /usr/share/nginx/html;
	index index.html;	
    }  
}

備註

location下的root和alias區別:

範例:

客戶端請求: http://localhost:8080/user/info/a.txt

nginx如果用root設定:nginx會去找資源:/home/html/user/info/a.txt

location ^~ /user {<!--{cke_protected}{C}%3C!%2D%2D%20%2D%2D%3E-->
root /home/html;#此处可以不以/结尾
}

nginx如果用alias設定:nginx會去找資源:/home/html/info/a.txt

location ^~ /user {<!--{cke_protected}{C}%3C!%2D%2D%20%2D%2D%3E-->
alias /home/html/;#此处以/结尾
}

以上是nginx多location怎麼配置的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:yisu.com。如有侵權,請聯絡admin@php.cn刪除