更新時間:2021年07月20日17時50分 來源:傳智教育 瀏覽次數(shù):
server_name指令
server_name:用來設(shè)置虛擬主機服務(wù)名稱。
127.0.0.1 、 localhost 、域名[m.xamj520.com | www.itheima.com]
語法 | server_name name ...; name可以提供多個中間用空格分隔 |
默認(rèn)值 | server_name ""; |
位置 | server |
關(guān)于server_name的配置方式有三種,分別是:
·精確匹配
·通配符匹配
·正則表達式匹配
配置方式一:精確匹配
如
server { listen 80; server_name m.xamj520.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.xamj520.com 127.0.0.1 www.itheima.cn
配置方式二:使用通配符配置
server_name中支持通配符"*",但需要注意的是通配符不能出現(xiàn)在域名的中間,只能出現(xiàn)在首段或尾段,如:
server { listen 80; server_name *.itcast.cn www.itheima.*; # m.xamj520.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
猜你喜歡: