您好,登錄后才能下訂單哦!
背景介紹
最近在個人的多個項目部署中遇到這樣一個問題,一個域名如何實現多個項目的訪問。因為不想自己單獨去申請域名證書和域名配置,便想到了這個方案,結合Nginx的location功能實現了自己的需求,便記錄下來。示例中是以PHP的項目演示,其他的語言類似同樣的方式進行部署。例如node的項目,可以在location中做一個驗證,然后使用porxy_pass反向代理模塊實現。
location模塊的匹配介紹
1.”=”前綴指令匹配,如果匹配成功,則停止其他匹配。
2.普通字符串指令匹配,順序是從長到短,匹配成功的location如果使用^~,則停止其他匹配(正則匹配)。
3.正則表達式指令匹配,按照配置文件里的順序,成功就停止其他匹配。
4.如果第三步中有匹配成功,則使用該結果,否則使用第二步結果。
注意點
1.匹配的順序是先匹配普通字符串,然后再匹配正則表達式。另外普通字符串匹配順序是根據配置中字符長度從長到短,也就是說使用普通字符串配置的location順序是無關緊要的,反正最后nginx會根據配置的長短來進行匹配,但是需要注意的是正則表達式按照配置文件里的順序測試。找到第一個匹配的正則表達式將停止搜索。
2.一般情況下,匹配成功了普通字符串location后還會進行正則表達式location匹配。有兩種方法改變這種行為,其一就是使用“=”前綴,這時執行的是嚴格匹配,并且匹配成功后立即停止其他匹配,同時處理這個請求;另外一種就是使用“^~”前綴,如果把這個前綴用于一個常規字符串那么告訴nginx 如果路徑匹配那么不測試正則表達式。
location = /uri
=開頭表示精確匹配,只有完全匹配上才能生效。
location ^~ /uri
^~ 開頭對URL路徑進行前綴匹配,并且在正則之前。
location ~ pattern
~開頭表示區分大小寫的正則匹配。
location ~* pattern
~*開頭表示不區分大小寫的正則匹配。
location /uri
不帶任何修飾符,也表示前綴匹配,但是在正則匹配之后。
location /
通用匹配,任何未匹配到其它location的請求都會匹配到,相當于switch中的default。
配置實例
server { listen 80; server_name test.com; index index.html index.htm index.php; charset koi8-r; access_log /var/log/nginx/host.access.log main; # 域名+項目1名稱 location ^~ /a1/ { alias /usr/share/nginx/html/a1/public/; } # 域名+項目2名稱 location ^~ /a2/ { alias /usr/share/nginx/html/a2/public/; } error_page 404 /404.html; # redirect server error pages to the static page /50x.html error_page 500 502 503 504 /50x.html; location = /50x.html { root /usr/share/nginx/html/500.html; } #pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000 location ~ \.php$ { root html; fastcgi_pass 127.0.0.1:9000; fastcgi_index index.php; fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name; include fastcgi_params; } location ~ /\.ht { deny all; } }
效果預覽
1.訪問a1項目
2.訪問a2項目
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對億速云的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。