日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 前端技术 > HTML >内容正文

HTML

前端开发掌握nginx常用功能之serverlocation匹配规则

發(fā)布時(shí)間:2023/12/18 HTML 40 豆豆
生活随笔 收集整理的這篇文章主要介紹了 前端开发掌握nginx常用功能之serverlocation匹配规则 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

nginx主要是公司運(yùn)維同學(xué)必須掌握的知識,涉及到反向代理、負(fù)載均衡等服務(wù)器配置。前端開發(fā)尤其是純前端開發(fā)來說對nginx接觸的并不多,但是在一些情況下,nginx還是需要前端自己來搞;例如我們公司的開發(fā)環(huán)境和測試環(huán)境,雖然qa可以幫助搞定配置,但是每新增一個前端模塊或者模塊nginx配置經(jīng)常變更都求著qa搞,麻煩別人還不如自己來搞,這樣更能理解自己的需求。這些都需要前端開發(fā)對nginx有所理解,下面我們來說說nginx最基礎(chǔ)的server和location匹配規(guī)則。

1. server匹配規(guī)則

nginx的server塊可以配置多個,那么一個請求該匹配那個server塊呢,這主要是根據(jù)server塊的server_name和listen來決定的。其中server_name僅僅檢查請求的“Host”頭以決定該請求應(yīng)由哪個虛擬主機(jī)來處理。

先看一個例子:

server {listen 8001;server_name *.net; }server {listen 8001;server_name baidu.net; }server {listen 8001;server_name baidu.*; }

通過測試,發(fā)現(xiàn)相同listen端口的情況下,多個server的匹配順序如下:

  • 完全匹配優(yōu)先級最高,匹配則終止
  • 通配符在前的優(yōu)先級其次,如*.com
  • 通配符在后的優(yōu)先級次之,如baidu.*
  • 正則匹配優(yōu)先級最低,如~^.www.test.com$

以上若都沒有匹配,那么其會走默認(rèn)的server,即:

  • 優(yōu)先選擇listen配置項(xiàng)后有default或default_server的server,若沒有則:
  • 找到匹配listen端口的第一個server塊

一種特殊情況,如果nginx中只為某個listen端口配置一個server塊的話,那么nginx是不會根據(jù)該端口的server_name進(jìn)行匹配的。因?yàn)橹挥幸粋€server域,那么根據(jù)上面沒有匹配的規(guī)則的情況下會走第一個匹配listen端口的server塊。

server {listen 8001;server_name baidu.net; } server { # server沒有配置listen的話,root用戶默認(rèn)是80端口,非root用戶默認(rèn)8080server_name server.com; }

如上面8001端口只有一個server的情況下,任何server_name訪問server_name:8001都會匹配上面server塊(前提是server_name對應(yīng)域名能請求到該機(jī)器上)。

另一種特殊情況,server塊配置的虛擬主機(jī)是基于域名和IP混合的。如下所示:

server {listen 192.168.1.1:8001;server_name example.org www.example.org;... } server {listen 192.168.1.1:8002;server_name example.com www.example.com;... }

這種情況下,其匹配順序是:

  • 首先,看請求的IP地址和端口是否匹配某個server配置塊中的listen指令配置,匹配則命中該server塊,否則執(zhí)行以下
  • 其次,看請求的Host頭是否匹配這個server塊中的某個server_name的值,匹配這命中,否則走默認(rèn)server。

第二點(diǎn)需要補(bǔ)充一下,看請求的Host頭是否匹配server_name,要滿足一個條件,即通過server_name指定的域名可以訪問到當(dāng)前nginx配置所在的機(jī)器,因?yàn)橥ㄟ^域名訪問nginx所在的機(jī)器最終還是通過ip的形式來訪問的。

比如,訪問www.example.org,最終通過dns解析出nginx所在的ip地址來進(jìn)行訪問的,又因?yàn)樵搒erver監(jiān)聽8001端口,所以通過www.example.org:8001也可以命中192.168.1.1:8001所在的server塊。

2. location匹配規(guī)則

一個示例:

location = / {# 精確匹配 / ,主機(jī)名后面不能帶任何字符串[ configuration A ] }location / {# 因?yàn)樗械牡刂范家?/ 開頭,所以這條規(guī)則將匹配到所有請求# 但是正則和最長字符串會優(yōu)先匹配[ configuration B ] }location /documents/ {# 匹配任何以 /documents/ 開頭的地址,匹配符合以后,還要繼續(xù)往下搜索# 只有后面的正則表達(dá)式?jīng)]有匹配到時(shí),這一條才會采用這一條[ configuration C ] }location ~ /documents/Abc {# 匹配任何以 /documents/Abc 開頭的地址,匹配符合以后,還要繼續(xù)往下搜索# 只有后面的正則表達(dá)式?jīng)]有匹配到時(shí),這一條才會采用這一條[ configuration CC ] }location ^~ /images/ {# 匹配任何以 /images/ 開頭的地址,匹配符合以后,停止往下搜索正則,采用這一條。[ configuration D ] }location ~* \.(gif|jpg|jpeg)$ {# 匹配所有以 gif,jpg或jpeg 結(jié)尾的請求# 然而,所有請求 /images/ 下的圖片會被 config D 處理,因?yàn)?^~ 到達(dá)不了這一條正則[ configuration E ] }location /images/ {# 字符匹配到 /images/,繼續(xù)往下,會發(fā)現(xiàn) ^~ 存在[ configuration F ] }location /images/abc {# 最長字符匹配到 /images/abc,繼續(xù)往下,會發(fā)現(xiàn) ^~ 存在# F與G的放置順序是沒有關(guān)系的[ configuration G ] }location ~ /images/abc/ {# 只有去掉 config D 才有效:先最長匹配 config G 開頭的地址,繼續(xù)往下搜索,匹配到這一條正則,采用[ configuration H ] }location ~* /js/.*/\.js {# 不區(qū)分大小寫匹配[ configuration I ] }
  • 以= 開頭表示精確匹配,匹配則終止后續(xù)查找;如 A 中只匹配根目錄結(jié)尾的請求,后面不能帶任何字符串.
  • 以^~ 開頭表示uri以某個常規(guī)字符串開頭,不是正則匹配,匹配則終止后續(xù)查找,包括正則匹配,它依然支持最長匹配原則
  • 以~ 開頭表示區(qū)分大小寫的正則匹配;
  • 以~* 開頭表示不區(qū)分大小寫的正則匹配
  • 以/ 通用匹配, 如果沒有其它匹配,任何請求都會匹配到

location 順序 no優(yōu)先級:

關(guān)于location的優(yōu)先級需要認(rèn)知三點(diǎn):

  • 先匹配普通location,后匹配正則location;因?yàn)檎齽t會覆蓋普通
  • 普通location匹配與順序無關(guān),因?yàn)椴捎米铋L匹配原則;正則location匹配與順序有關(guān),但是正則location依然采用最長匹配原則
  • 普通location指定了^~則一旦該普通規(guī)則匹配上,則不會進(jìn)行后續(xù)匹配了,即使是正則匹配;=嚴(yán)格匹配一旦匹配,也不會后續(xù)正則匹配

所以,location的優(yōu)先級如下:

(location =) > (location ^~ 路徑) > (location ~,~* 正則順序) > (location 完整路徑) > (location 部分起始路徑) > (/)

按照上面的location寫法,以下的匹配示例成立:

  • / -> config A
    精確完全匹配,即使/index.html也匹配不了
  • /downloads/download.html -> config B
    匹配B以后,往下沒有任何匹配,采用B
  • /images/1.gif -> configuration D
    匹配到F,往下匹配到D,停止往下
  • /images/abc/def -> config D
    最長匹配到G,往下匹配D,停止往下
    你可以看到 任何以/images/開頭的都會匹配到D并停止,FG寫在這里是沒有任何意義的,H是永遠(yuǎn)輪不到的,這里只是為了說明匹配順序
  • /documents/document.html -> config C
    匹配到C,往下沒有任何匹配,采用C
  • /documents/1.jpg -> configuration E
    匹配到C,往下正則匹配到E
  • /documents/Abc.jpg -> config CC
    最長匹配到C,往下正則順序匹配到CC,不會往下到E

實(shí)際使用建議

所以實(shí)際使用中,個人覺得至少有三個匹配規(guī)則定義,如下: #直接匹配網(wǎng)站根,通過域名訪問網(wǎng)站首頁比較頻繁,使用這個會加速處理,官網(wǎng)如是說。 #這里是直接轉(zhuǎn)發(fā)給后端應(yīng)用服務(wù)器了,也可以是一個靜態(tài)首頁 # 第一個必選規(guī)則 location = / {proxy_pass http://tomcat:8080/index } # 第二個必選規(guī)則是處理靜態(tài)文件請求,這是nginx作為http服務(wù)器的強(qiáng)項(xiàng) # 有兩種配置模式,目錄匹配或后綴匹配,任選其一或搭配使用 location ^~ /static/ {root /webroot/static/; } location ~* \.(gif|jpg|jpeg|png|css|js|ico)$ {root /webroot/res/; } #第三個規(guī)則就是通用規(guī)則,用來轉(zhuǎn)發(fā)動態(tài)請求到后端應(yīng)用服務(wù)器 #非靜態(tài)文件請求就默認(rèn)是動態(tài)請求,自己根據(jù)實(shí)際把握 #畢竟目前的一些框架的流行,帶.php,.jsp后綴的情況很少了 location / {proxy_pass http://tomcat:8080/ }

參考

  • https://tengine.taobao.org/nginx_docs/cn/docs/http/request_processing.html
  • http://tengine.taobao.org/book/chapter_02.html
  • http://nginx.org/en/docs/http/ngx_http_rewrite_module.html
  • http://www.nginx.cn/216.html
  • http://www.ttlsa.com/nginx/nginx-rewriting-rules-guide/
  • http://fantefei.blog.51cto.com/2229719/919431
  • http://seanlook.com/2015/05/17/nginx-location-rewrite/

轉(zhuǎn)載于:https://www.cnblogs.com/wonyun/p/10309491.html

總結(jié)

以上是生活随笔為你收集整理的前端开发掌握nginx常用功能之serverlocation匹配规则的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。