簡單梳理一下nginx中關(guān)于server 和location的配置.
比如URL:www.mask_dev2.com:9999/login/
server管的前半部分,即:www.mask_dev2.com:9999
location管的是后半部分,即:/login/
一個(gè)nginx可以配置多個(gè)server。
每個(gè)server可以配置多個(gè)location。
URL的前半部分控制選擇哪一個(gè)server,后半部分控制選擇哪一個(gè)location,最終決定往哪里去請求.
server的配置
server {
listen 9999;
server_name www.mask_dev2.cn;
location / {
default_type text/html;
content_by_lua '
ngx.say("<p>first</p>")
';
}
}
server {
listen 9999;
server_name www.mask_dev2.*;
location / {
default_type text/html;
content_by_lua '
ngx.say("<p>second</p>")
';
}
}
server {
listen 9998;
server_name _;
location / {
default_type text/html;
content_by_lua '
ngx.say("<p>third</p>")
';
}
}
首先,請求nginx的地址,肯定是請求的nginx所在的服務(wù)器,也就是說ip是固定的。
也就是說,無所謂server_name是什么,都是指的當(dāng)前服務(wù)器.
那么當(dāng)前服務(wù)器是怎樣對應(yīng)多個(gè)域名呢,這個(gè)只需要在相應(yīng)的dns服務(wù)器中進(jìn)行添加,就行了,比如暫時(shí)把本機(jī)當(dāng)成dns服務(wù)器,修改hosts
127.0.0.1 localhost
127.0.0.1 www.mask_dev2.cn
127.0.0.1 www.mask_dev2.com
server匹配順序
server_name與host匹配優(yōu)先級如下:
1、完全匹配
2、通配符在前的,如*.test.com
3、在后的,如www.test.*
4、正則匹配,如~^\.www\.test\.com$
如果都不匹配
1、優(yōu)先選擇listen配置項(xiàng)后有default或default_server的
2、找到匹配listen端口的第一個(gè)server塊
location配置
找到server之后,再去找具體的location
server {
listen 9998;
server_name _;
location = / {
#規(guī)則A
}
location = /login {
#規(guī)則B
}
location ^~ /static/ {
#規(guī)則C
}
location ~ \.(gif|jpg|png|js|css)$ {
#規(guī)則D
}
location ~* \.png$ {
#規(guī)則E
}
location !~ \.xhtml$ {
#規(guī)則F
}
location !~* \.xhtml$ {
#規(guī)則G
}
location / {
#規(guī)則H
}
語法規(guī)則:
location [=||*|^~] uri { … }
- = 開頭表示精確匹配
- ^~ 開頭表示uri以某個(gè)常規(guī)字符串開頭,理解為匹配 url路徑即可。nginx不對url做編碼,因此請求為/static/20%/aa,可以被規(guī)則^~ static /aa匹配到(注意是空格)。
- ~ 開頭表示區(qū)分大小寫的正則匹配
- ~* 開頭表示不區(qū)分大小寫的正則匹配
- !和!*分別為區(qū)分大小寫不匹配及不區(qū)分大小寫不匹配 的正則
- / 通用匹配,任何請求都會(huì)匹配到。
- 多個(gè)location配置的情況下匹配順序?yàn)椋▍⒖假Y料而來,還未實(shí)際驗(yàn)證,試試就知道了,不必拘泥,僅供參考):
首先匹配 =,其次匹配^~, 其次是按文件中順序的正則匹配,最后是交給 / 通用匹配。當(dāng)有匹配成功時(shí)候,停止匹配,按當(dāng)前匹配規(guī)則處理請求。
但是一般沒有這么復(fù)雜,有3點(diǎn)。
- 默認(rèn)請求。
- 頁面請求.
- 后臺(tái)邏輯請求.
#直接匹配網(wǎng)站根,通過域名訪問網(wǎng)站首頁比較頻繁,使用這個(gè)會(huì)加速處理,官網(wǎng)如是說。
#這里是直接轉(zhuǎn)發(fā)給后端應(yīng)用服務(wù)器了,也可以是一個(gè)靜態(tài)首頁
# 第一個(gè)必選規(guī)則
location = / {
proxy_pass http://tomcat:8080/index
}
# 第二個(gè)必選規(guī)則是處理靜態(tài)文件請求,這是nginx作為http服務(wù)器的強(qiáng)項(xiàng)
# 有兩種配置模式,目錄匹配或后綴匹配,任選其一或搭配使用
location ~* \.(gif|jpg|jpeg|png|css|js|ico)$ {
root /webroot/res/;
}
#第三個(gè)規(guī)則就是通用規(guī)則,用來轉(zhuǎn)發(fā)動(dòng)態(tài)請求到后端應(yīng)用服務(wù)器
#非靜態(tài)文件請求就默認(rèn)是動(dòng)態(tài)請求,自己根據(jù)實(shí)際把握
#畢竟目前的一些框架的流行,帶.php,.jsp后綴的情況很少了
location / {
proxy_pass http://127.0.0.1:8080/
}
總結(jié)
比如,現(xiàn)在同時(shí)啟動(dòng) 前臺(tái)系統(tǒng),和后臺(tái)系統(tǒng),就可以用兩個(gè)server(可以配置host為api,admin,或者直接修改端口也可以),每個(gè)server中3個(gè)location來確定具體頁面的請求.
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。