更新時間:2021年07月16日16時26分 來源:傳智教育 瀏覽次數(shù):
Nginx靜態(tài)資源的配置指令
listen指令
listen:用來配置監(jiān)聽端口。
語法 | listen address[:port] [default_server]...; listen port [default_server]...; |
默認(rèn)值 | listen *:80 | *:8000 |
位置 | server |
listen的設(shè)置比較靈活,我們通過幾個例子來把常用的設(shè)置方式熟悉下:
listen 127.0.0.1:8000; // listen localhost:8000 監(jiān)聽指定的IP和端口
listen 127.0.0.1; 監(jiān)聽指定IP的所有端口
listen 8000; 監(jiān)聽指定端口上的連接
listen *:8000; 監(jiān)聽指定端口上的連接
default_server屬性是標(biāo)識符,用來將此虛擬主機設(shè)置成默認(rèn)主機。所謂的默認(rèn)主機指的是如果沒有匹配到對應(yīng)的address:port,則會默認(rèn)執(zhí)行的。如果不指定默認(rèn)使用的是第一個server。
server{ listen 8080; server_name 127.0.0.1; location /{ root html; index index.html; } } server{ listen 8080 default_server; server_name localhost; default_type text/plain; return 444 'This is a error request'; }
server_name指令
server_name:用來設(shè)置虛擬主機服務(wù)名稱。
127.0.0.1 、 localhost 、域名[www.baidu.com | www.jd.com]
語法 | server_name name ...; name可以提供多個中間用空格分隔 |
默認(rèn)值 | server_name ""; |
位置 | server |
關(guān)于server_name的配置方式有三種,分別是:
·精確匹配
·通配符匹配
·正則表達式匹配
配置方式一:精確匹配
如
server { listen 80; server_name m.metathetuscanyresort.com www.itheima.cn; ... }
補充小知識點:
hosts是一個沒有擴展名的系統(tǒng)文件,可以用記事本等工具打開,其作用就是將一些常用的網(wǎng)址域名與其對應(yīng)的IP地址建立一個關(guān)聯(lián)“數(shù)據(jù)庫”,當(dāng)用戶在瀏覽器中輸入一個需要登錄的網(wǎng)址時,系統(tǒng)會首先自動從hosts文件中尋找對應(yīng)的IP地址,一旦找到,系統(tǒng)會立即打開對應(yīng)網(wǎng)頁,如果沒有找到,則系統(tǒng)會再將網(wǎng)址提交DNS域名解析服務(wù)器進行IP地址的解析。
windows:C:\Windows\System32\drivers\etc
centos:/etc/hosts
因為域名是要收取一定的費用,所以我們可以使用修改hosts文件來制作一些虛擬域名來使用。需要修改 /etc/hosts文件來添加
vim /etc/hosts 127.0.0.1 m.metathetuscanyresort.com 127.0.0.1 www.itheima.cn
配置方式二:使用通配符配置
server_name中支持通配符"*",但需要注意的是通配符不能出現(xiàn)在域名的中間,只能出現(xiàn)在首段或尾段,如:
server { listen 80; server_name *.itcast.cn www.itheima.*; # m.metathetuscanyresort.com abc.itcast.cn www.itheima.cn www.itheima.com ... }
下面的配置就會報錯
server { listen 80; server_name www.*.cn www.itheima.c* ... }
配置三:使用正則表達式配置
server_name中可以使用正則表達式,并且使用~作為正則表達式字符串的開始標(biāo)記。
常見的正則表達式
代碼 | 說明 |
^ | 匹配搜索字符串開始位置 |
$ | 匹配搜索字符串結(jié)束位置 |
. | 匹配除換行符\n之外的任何單個字符 |
\ | 轉(zhuǎn)義字符,將下一個字符標(biāo)記為特殊字符 |
[xyz] | 字符集,與任意一個指定字符匹配 |
[a-z] | 字符范圍,匹配指定范圍內(nèi)的任何字符 |
\w | 與以下任意字符匹配 A-Z a-z 0-9 和下劃線,等效于[A-Za-z0-9_] |
\d | 數(shù)字字符匹配,等效于[0-9] |
{n} | 正好匹配n次 |
{n,} | 至少匹配n次 |
{n,m} | 匹配至少n次至多m次 |
* | 零次或多次,等效于{0,} |
+ | 一次或多次,等效于{1,} |
? | 零次或一次,等效于{0,1} |
配置如下:
server{ listen 80; server_name ~^www\.(\w+)\.com$; default_type text/plain; return 200 $1 $2 ..; }
注意 ~后面不能加空格,括號可以取值
匹配執(zhí)行順序
由于server_name指令支持通配符和正則表達式,因此在包含多個虛擬主機的配置文件中,可能會出現(xiàn)一個名稱被多個虛擬主機的server_name匹配成功,當(dāng)遇到這種情況,當(dāng)前的請求交給誰來處理呢?
server{ listen 80; server_name ~^www\.\w+\.com$; default_type text/plain; return 200 'regex_success'; } server{ listen 80; server_name www.itheima.*; default_type text/plain; return 200 'wildcard_after_success'; } server{ listen 80; server_name *.itheima.com; default_type text/plain; return 200 'wildcard_before_success'; } server{ listen 80; server_name www.itheima.com; default_type text/plain; return 200 'exact_success'; } server{ listen 80 default_server; server_name _; default_type text/plain; return 444 'default_server not found server'; }
結(jié)論:
exact_success wildcard_before_success wildcard_after_success regex_success default_server not found server!!
No1:準(zhǔn)確匹配server_name
No2:通配符在開始時匹配server_name成功
No3:通配符在結(jié)束時匹配server_name成功
No4:正則表達式匹配server_name成功
No5:被默認(rèn)的default_server處理,如果沒有指定默認(rèn)找第一個server
location指令
server{ listen 80; server_name localhost; location / { } location /abc{ } ... }
location:用來設(shè)置請求的URI
默認(rèn)值 | — |
語法 | location [ = | ~ | ~* | ^~ |@ ] uri{...} |
位置 | server,location |
uri變量是待匹配的請求字符串,可以不包含正則表達式,也可以包含正則表達式,那么nginx服務(wù)器在搜索匹配location的時候,是先使用不包含正則表達式進行匹配,找到一個匹配度最高的一個,然后在通過包含正則表達式的進行匹配,如果能匹配到直接訪問,匹配不到,就使用剛才匹配度最高的那個location來處理請求。
屬性介紹:
不帶符號,要求必須以指定模式開始
server { listen 80; server_name 127.0.0.1; location /abc{ default_type text/plain; return 200 "access success"; } } 以下訪問都是正確的 http://192.168.200.133/abc http://192.168.200.133/abc?p1=TOM http://192.168.200.133/abc/ http://192.168.200.133/abcdef
= : 用于不包含正則表達式的uri前,必須與指定的模式精確匹配
server { listen 80; server_name 127.0.0.1; location =/abc{ default_type text/plain; return 200 "access success"; } } 可以匹配到 http://192.168.200.133/abc http://192.168.200.133/abc?p1=TOM 匹配不到 http://192.168.200.133/abc/ http://192.168.200.133/abcdef
~ : 用于表示當(dāng)前uri中包含了正則表達式,并且區(qū)分大小寫
~*: 用于表示當(dāng)前uri中包含了正則表達式,并且不區(qū)分大小寫
換句話說,如果uri包含了正則表達式,需要用上述兩個符合來標(biāo)識
server { listen 80; server_name 127.0.0.1; location ~^/abc\w${ default_type text/plain; return 200 "access success"; } } server { listen 80; server_name 127.0.0.1; location ~*^/abc\w${ default_type text/plain; return 200 "access success"; } }
^~: 用于不包含正則表達式的uri前,功能和不加符號的一致,唯一不同的是,如果模式匹配,那么就停止搜索其他模式了。
server { listen 80; server_name 127.0.0.1; location ^~/abc{ default_type text/plain; return 200 "access success"; } }
設(shè)置請求資源的目錄root / alias
root:設(shè)置請求的根目錄
語法 | root path; |
默認(rèn)值 | root html; |
位置 | http、server、location |
path為Nginx服務(wù)器接收到請求以后查找資源的根目錄路徑。
alias:用來更改location的URI
語法 | alias path; |
默認(rèn)值 | — |
位置 | location |
path為修改后的根路徑。
以上兩個指令都可以來指定訪問資源的路徑,那么這兩者之間的區(qū)別是什么?
舉例說明:
(1)在/usr/local/nginx/html目錄下創(chuàng)建一個 images目錄,并在目錄下放入一張圖片mv.png圖片
location /images { root /usr/local/nginx/html; }
訪問圖片的路徑為:
http://192.168.200.133/images/mv.png
(2)如果把root改為alias
location /images { alias /usr/local/nginx/html; }
再次訪問上述地址,頁面會出現(xiàn)404的錯誤,查看錯誤日志會發(fā)現(xiàn)是因為地址不對,所以驗證了:
root的處理結(jié)果是: root路徑+location路徑 /usr/local/nginx/html/images/mv.png alias的處理結(jié)果是:使用alias路徑替換location路徑 /usr/local/nginx/html/images
需要在alias后面路徑改為
location /images { alias /usr/local/nginx/html/images; }
(3)如果location路徑是以/結(jié)尾,則alias也必須是以/結(jié)尾,root沒有要求
將上述配置修改為
location /images/ { alias /usr/local/nginx/html/images; }
訪問就會出問題,查看錯誤日志還是路徑不對,所以需要把alias后面加上 /
小結(jié):
root的處理結(jié)果是: root路徑+location路徑
alias的處理結(jié)果是:使用alias路徑替換location路徑
alias是一個目錄別名的定義,root則是最上層目錄的含義。
如果location路徑是以/結(jié)尾,則alias也必須是以/結(jié)尾,root沒有要求
index指令
index:設(shè)置網(wǎng)站的默認(rèn)首頁
語法 | index file ...; |
默認(rèn)值 | index index.html; |
位置 | http、server、location |
index后面可以跟多個設(shè)置,如果訪問的時候沒有指定具體訪問的資源,則會依次進行查找,找到第一個為止。
舉例說明:
location / { root /usr/local/nginx/html; index index.html index.htm; } 訪問該location的時候,可以通過 http://ip:port/,地址后面如果不添加任何內(nèi)容,則默認(rèn)依次訪問index.html和index.htm,找到第一個來進行返回
error_page指令
error_page:設(shè)置網(wǎng)站的錯誤頁面
語法 | error_page code ... [=[response]] uri; |
默認(rèn)值 | — |
位置 | http、server、location...... |
當(dāng)出現(xiàn)對應(yīng)的響應(yīng)code后,如何來處理。
舉例說明:
(1)可以指定具體跳轉(zhuǎn)的地址
server { error_page 404 http://m.metathetuscanyresort.com; }
(2)可以指定重定向地址
server{ error_page 404 /50x.html; error_page 500 502 503 504 /50x.html; location =/50x.html{ root html; } }
(3)使用location的@符合完成錯誤信息展示
server{ error_page 404 @jump_to_error; location @jump_to_error { default_type text/plain; return 404 'Not Found Page...'; } }
可選項=[response]的作用是用來將相應(yīng)代碼更改為另外一個
server{ error_page 404 =200 /50x.html; location =/50x.html{ root html; } }
這樣的話,當(dāng)返回404找不到對應(yīng)的資源的時候,在瀏覽器上可以看到,最終返回的狀態(tài)碼是200,這塊需要注意下,編寫error_page后面的內(nèi)容,404后面需要加空格,200前面不能加空格
將本頁面鏈接http://m.metathetuscanyresort.com/news/20210716/1626170109.shtml發(fā)送給QQ:435946716,免費獲取上面課程全套視頻、筆記和源碼。
猜你喜歡: