什么是NginxRewrite模塊

今天就跟大家聊聊有關(guān)什么是Nginx Rewrite模塊,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。

在長治等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強發(fā)展的系統(tǒng)性、市場前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務(wù)理念,為客戶提供成都網(wǎng)站設(shè)計、網(wǎng)站建設(shè) 網(wǎng)站設(shè)計制作按需設(shè)計,公司網(wǎng)站建設(shè),企業(yè)網(wǎng)站建設(shè),高端網(wǎng)站設(shè)計,營銷型網(wǎng)站,成都外貿(mào)網(wǎng)站建設(shè)公司,長治網(wǎng)站建設(shè)費用合理。

Rewrite跳轉(zhuǎn)場景

URL看起來更規(guī)范,合理
企業(yè)會將動態(tài)URL地址偽裝成靜態(tài)地址提供服務(wù)
網(wǎng)址換新域名后,讓舊的訪問跳轉(zhuǎn)到新的域名上
服務(wù)端某些業(yè)務(wù)調(diào)整

Rewrite跳轉(zhuǎn)實現(xiàn)

什么是Nginx Rewrite模塊

Rewrite實用場景

  • Nginx跳轉(zhuǎn)需求的實現(xiàn)方式
    使用rewrite進(jìn)行匹配跳轉(zhuǎn)
    使用if匹配全局變量后跳轉(zhuǎn)
    使用location匹配再跳轉(zhuǎn)

  • rewrite放在server{},if{},location{}段中

  • 對域名或參數(shù)字符串
    使用if全局變量匹配
    使用proxy_pass反向代理

常用的正則表達(dá)式元字符

字符說明
^匹配輸入字符串的起始位置
$匹配輸入字符串的結(jié)束位置
*匹配前面的字符零次或多次
+匹配前面的字符一次或多次
匹配前面的字符零次或一次
.匹配除\n之外的任何單個字符,使用諸如"[.\n]"之類的模式,可匹配包括"\n"在內(nèi)的任意字符
\d匹配純數(shù)字  [0-9]
{n}重復(fù)多次
{n,}重復(fù)n次或更多次
[c]匹配單個字符c
[a-z]匹配a-z小寫字母的任意一個
[a-zA-Z]匹配a-z小寫字母或A-Z大寫字母的任意一個

Rewrite命令

語法:
rewrite <regex>            <replacement>             [flag];
            正則                  跳轉(zhuǎn)后的內(nèi)容               rewrite支持的flag標(biāo)記

flag標(biāo)記說明:

標(biāo)記說明
last相當(dāng)于Apache的[L]標(biāo)記,表示完成rewrite
break本條規(guī)則匹配完成即終止,不再匹配后面的任何規(guī)則
redirect返回302臨時重定向,瀏覽器地址會顯示跳轉(zhuǎn)后的URL地址,爬蟲不會更新url
permanent返回301永久重定向,瀏覽器地址欄會顯示跳轉(zhuǎn)后的URL地址,爬蟲更新url

last和break比較:


lastbreak
使用場景一般寫在server和if中一般使用在location中
URL匹配不終止重寫后的url匹配終止重寫后的url匹配

location分類

分類:
    location = patt {} [精準(zhǔn)匹配]
    location patt {} [一般匹配]
    location ~ patt {} [正則匹配]

正則匹配的常用表達(dá)式:

標(biāo)記說明
~執(zhí)行一個正則匹配,區(qū)分大小寫
~*執(zhí)行一個正則匹配,不區(qū)分大小寫
!~執(zhí)行一個正則匹配,區(qū)分大小寫不匹配
!~*執(zhí)行一個正則匹配,不區(qū)分大小寫不匹配
^~普通字符匹配;使用前綴匹配。如果匹配成功,則不再匹配其他location
=普通字符精準(zhǔn)匹配。也就是完全匹配
@定義一個命名的location,使用在內(nèi)部定向時

location優(yōu)先級

**相同類型的表達(dá)式,字符創(chuàng)長的會優(yōu)先匹配**
**按優(yōu)先級排列**
    = 類型
    ^~ 類型表達(dá)式
    正則表達(dá)式(~和~*)類型
    常規(guī)字符串匹配類型,按前綴匹配
    通常匹配(/),如果沒有其他匹配,任何請求都會匹配到

比較rewrite和location

**相同點**
        都能實現(xiàn)跳轉(zhuǎn)
**不同點**
        rewrite是在同一域名內(nèi)更改獲取資源的路徑
        location是對一類路徑做控制訪問或方向代理,還可以proxy_pass到其他機器
**rewrite會寫在location里執(zhí)行順序**
        執(zhí)行server塊里面的rewrite指令
        執(zhí)行l(wèi)ocation匹配
        執(zhí)行選定的location中的rewrite指令

location優(yōu)先級的示例

##精確匹配/,主機名后面不能帶任何字符串
location = / {
[ configuration A ]     
}

##所有的地址都以/開頭,這條規(guī)則將匹配到所有請求,但正則和最長字符串會優(yōu)先匹配
location  / {
[ configuration B ]     
}

##匹配任何以/documents/開頭的地址,當(dāng)后面正則表達(dá)式?jīng)]有匹配到時,才起作用
location /documents/ {
[ configuration C ]
}

##匹配任何以/documents/abc開頭的地址,當(dāng)后面正則表達(dá)式?jīng)]有匹配到時,才會起作用
location ~ /documents/abc {
[ configuration D ]
}

##以/images/開頭的地址,匹配符合后,停止往下匹配
location ^~ /images/ {
[ configuration E ]
}

##匹配所有以gif結(jié)尾的請求,/images/下的圖片會被[configuration E]處理,因為^~的優(yōu)先級更高
location ~* \.(gif|jpg|jpeg)$ {
[ configuration F ]
}

##最長字符匹配到/images/abc,優(yōu)先級最低
location /images/abc {
[ configuration G ]
}

##以/images/abc開頭的,優(yōu)先級次之
location ~ /images/abc {
[ configuration H ]
}

##如果和正則~/images/abc/1.html相比,正則優(yōu)先級更高
location /images/abc/1.html {
[ configuration I ]
}

location優(yōu)先級規(guī)則

匹配某個具體文件:
(location = 完整路徑)>(location ^~完整路徑)>(location ~完整路徑)>(location ~完整路徑)>(location 完整路徑)>(location /)
用目錄做匹配訪問某個文件:
(location = 目錄)>(location ^~目錄/)>(location ~ 目錄)>(location ~
目錄)>(location 目錄)>(location /)

Nginx模塊

什么是Nginx Rewrite模塊

1,Nginx 工作原理

Nginx 由內(nèi)核和模塊組成。
Nginx 本身做的工作實際很少,當(dāng)它接到一個 HTTP 請求時, 它僅僅是通過查找配置文件將此次請求映射到一個 location block,而此 location 中所配 置的各個指令則會啟動不同的模塊去完成工作,因此模塊可以看做 Nginx 真正的勞動工作者。

?通常一個 location 中的指令會涉及一個 handler 模塊和多個 filter 模塊(當(dāng)然,多個 location 可以復(fù)用同一個模塊)。handler 模塊負(fù)責(zé)處理請求,完成響應(yīng)內(nèi)容的生成,而 filter 模塊對響應(yīng)內(nèi)容進(jìn)行處理。 用戶根據(jù)自己的需要所開發(fā)的模塊都屬于第三方模塊。正是有了這么多模塊的支撐, Nginx 的功能才會如此強大。
Nginx 的模塊從結(jié)構(gòu)上分為核心模塊、基礎(chǔ)模塊和第三方模塊
核心模塊:HTTP 模塊、EVENT 模塊和 MAIL 模塊;
基礎(chǔ)模塊:HTTP Access 模塊、HTTP FastCGI 模塊、HTTP Proxy 模塊和 HTTP Rewrite 模塊;
第三方模塊:HTTP Upstream Request Hash 模塊、Notice 模塊和 HTTP Access Key 模 塊。
Nginx 的模塊從功能上分為如下三類:
Handlers(處理器模塊):此類模塊直接處理請求,并進(jìn)行輸出內(nèi)容和修改 headers 信息等操作。Handlers 處理器模塊一般只能有一個; Filters(過濾器模塊):此類模塊主要對其他處理器模塊輸出的內(nèi)容進(jìn)行修改操作,最后由 Nginx 輸出; Proxies(代理類模塊):此類模塊是 Nginx 的 HTTP Upstream 之類的模塊,這些模塊主要與后端一些服務(wù)比如 FastCGI 等進(jìn)行交互,實現(xiàn)服務(wù)代理和負(fù)載均衡等功能。

2. Nginx 的進(jìn)程模型 在工作方式上,Nginx 分為單工作進(jìn)程和多工作進(jìn)程兩種模式。

?在單工作進(jìn)程模式下,除主進(jìn)程外,還有一個工作進(jìn)程,工作進(jìn)程是單線程的;
在多工作進(jìn)程模式下,每個工作進(jìn)程包含多個線程。Nginx 默認(rèn)為單工作進(jìn)程模式。

?Nginx 在啟動后,會有一個 master 進(jìn)程和多個 worker 進(jìn)程。
master 進(jìn)程主要用來管理 worker 進(jìn)程,主要包含:接收來自外界的信號,向各 worker 進(jìn)程發(fā)送信號,監(jiān)控 worker 進(jìn)程的運行狀態(tài),當(dāng) worker 進(jìn)程退出后(異常情況下),會自動 重新啟動新的 worker 進(jìn)程。 master 進(jìn)程充當(dāng)整個進(jìn)程組與用戶的交互接口,同時對進(jìn)程進(jìn)行監(jiān)護(hù)。它不需要處理網(wǎng)絡(luò)事件,不負(fù)責(zé)業(yè)務(wù)的執(zhí)行,只會通過管理worker 進(jìn)程來實現(xiàn)重啟服務(wù)、平滑升級、更換日志文件、配置文件實時生效等功能。

3.Nginx+FastCGI運行原理

?Nginx 不支持對外部程序的直接調(diào)用或者解析,所有的外部程序(包括 PHP)必須通過FastCGI 接口來調(diào)用。FastCGI 接口在 Linux 下是 socket(這個 socket 可以是文件 socket, 也可以是 ip socket)。 wrapper 為了調(diào)用 CGI 程序,還需要一個 FastCGI 的 wrapper(wrapper 可以理解為用于啟動另一個程序的程序),這個 wrapper 綁定在某個固定 socket 上,如端口或者文件 socket。當(dāng) Nginx 將 CGI 請求發(fā)送給這個 socket 的時候,通過 FastCGI 接口,wrapper 接收到請求,然后 Fork(派生)出一個新的線程,這個線程調(diào)用解釋器或者外部程序處理腳本并讀取返回數(shù)據(jù);接著 wrapper 再將返回的數(shù)據(jù)通過 FastCGI 接口,沿著固定的 socket傳遞給 Nginx;最后 Nginx 將返回的數(shù)據(jù)(html 頁面或者圖片)發(fā)送給客戶端。

看完上述內(nèi)容,你們對什么是Nginx Rewrite模塊有進(jìn)一步的了解嗎?如果還想了解更多知識或者相關(guān)內(nèi)容,請關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝大家的支持。

網(wǎng)站名稱:什么是NginxRewrite模塊
轉(zhuǎn)載來源:http://muchs.cn/article44/pieohe.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站營銷網(wǎng)站內(nèi)鏈、云服務(wù)器、企業(yè)網(wǎng)站制作、小程序開發(fā)、手機網(wǎng)站建設(shè)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

搜索引擎優(yōu)化