Nginx虛擬目錄alias和root目錄

2022-06-25 01:24:10 字數 1716 閱讀 1984

nginx是通過alias設定虛擬目錄,在nginx的配置中,alias目錄和root目錄是有區別的:

1)alias指定的目錄是準確的,即location匹配訪問的path目錄下的檔案直接是在alias目錄下查詢的;

2)root指定的目錄是location匹配訪問的path目錄的上一級目錄,這個path目錄一定要是真實存在root指定目錄下的;

3)使用alias標籤的目錄塊中不能使用rewrite的break(具體原因不明);另外,alias指定的目錄後面必須要加上"/"符號!!

4)alias虛擬目錄配置中,location匹配的path目錄如果後面不帶"/",那麼訪問的url位址中這個path目錄後面加不加"/"不影響訪問,訪問時它會自動加上"/";

但是如果location匹配的path目錄後面加上"/",那麼訪問的url位址中這個path目錄必須要加上"/",訪問時它不會自動加上"/"。如果不加上"/",訪問就會失敗!

5)root目錄配置中,location匹配的path目錄後面帶不帶"/",都不會影響訪問。

舉例說明(比如nginx配置的網域名稱是www.colorgg.com):

示例一location /huan/

在上面alias虛擬目錄配置下,訪問實際指定的是/home/www/huan/a.html。

注意:alias指定的目錄後面必須要加上"/",即/home/www/huan/不能改成/home/www/huan

上面的配置也可以改成root目錄配置,如下,這樣nginx就會去/home/www/huan下尋找的訪問資源,兩者配置後的訪問效果是一樣的!

location /huan/ 

示例二上面的例子中alias設定的目錄名和location匹配訪問的path目錄名一致,這樣可以直接改成root目錄配置;那要是不一致呢?

再看一例:

location /web/

訪問的時候就會去/home/www/html/下尋找訪問資源。

這樣的話,還不能直接改成root目錄配置。

如果非要改成root目錄配置,就只能在/home/www下將html->web(做軟連線,即快捷方式),如下:

location /web/

# ln -s /home/www/web /home/www/html       //即保持/home/www/web和/home/www/html內容一直

所以,一般情況下,在nginx配置中的良好習慣是:

1)在location /中配置root目錄;

2)在location /path中配置alias虛擬目錄。

如下一例:

server

location /haha

location /wang

*************************====再看下面一例*************************====

server

location /document/

} [root@web01 vhosts]# ll /data/web/total

410:22

document

15:00

kevin

如上配置後,則:

訪問http:

就會找到/data/web/kevin/admin目錄

訪問http://

www.colorgg.com/document 就會找到/data/web/document 目錄 (裡面是一些靜態資源)

Nginx虛擬目錄alias和root目錄

nginx是通過alias設定虛擬目錄,在nginx的配置中,alias目錄和root目錄是有區別的 1 alias指定的目錄是準確的,即location匹配訪問的path目錄下的檔案直接是在alias目錄下查詢的 2 root指定的目錄是location匹配訪問的path目錄的上一級目錄,這個pa...

Nginx之虛擬目錄 root與alias的區別

nginx其實沒有虛擬主機這個說法,因為它本來就是完完全全根據目錄來設計並工作的。如果非要給nginx安上乙個虛擬目錄的說法,那就只有alias比較 像 了。那alias標籤和root標籤到底有哪些區別呢?1 alias後跟的指定目錄是準確的,並且末尾必須加 否則找不到檔案 1 2 3 locati...

nginx 配置之 虛擬目錄

server location ht location phpadmin location php 要注意的是,location phpadmin 和 location phpadmin 是完全不同的。前者可以訪問到目錄,而後者將被重定向到伺服器,如 http 127.0.0.1 phpadmin ...