日韩在线首页I俄罗斯pornI男女猛烈激情XX00高潮动态I超碰免费97I乱人伦99久久I欧美日韩成人一区I最新日韩视频在线观看I粉嫩AV四季AV绯色AVI五月导航

×

這些nginx安裝配置你都了解嗎

分類:云服務資訊 編輯: 瀏覽量:100
2021-07-22 17:14:10
??Nginx多用于配置Web服務器。抽象來說,將Nginx配置為Web服務器就是定義處理哪些 URLS 和如何處理這些URLS 對應的請求,定義一些虛擬服務器,控制具有特定 IP 和域名的請求。Nginx 通過定義一系列 locations 來控制對 URIS 的選擇。每一個 location 定義了對映射到自己的請求的處理場景,返回一個文件或者代理請求,或者根據不同的錯誤代碼返回不同的錯誤頁面。另外,根據 URI 的不同,請求也可以被重定向到其它。下面就由新網小編和大家講一講nginx安裝配置。

??一、設置虛擬服務器

??listen:

??Nginx 配置文件至少包含一個 server 命令 ,用來定義虛擬服務器。當請求到來時, Nginx 會首先選擇一個虛擬服務器來處理該請求。

??虛擬服務器定義在 http 上下文中的 server 中:

??http{

??server{

??#Serverconfiguration

??}

??}

??注意: http 中可以定義多個 server

??server 配置塊使用 listen 命令監聽本機 IP 和端口號(包括 Unix domain socket and path),支持 IPv4、IPv6,IPv6地址需要用方括號括起來:

??server{

??listen127.0.0.1:8080;#IPv4地址,8080端口

??#listen[2001:3CA1:10F:1A:121B:0:0:10]:80;#IPv6地址,80端口

??#listen[::]:80;#聽本機的所有IPv4與IPv6地址,80端口

??#Therestofserverconfiguration

??}

??上述配置,如果不寫端口號,默認使用80端口,如果不寫 IP ,則監聽本機所有 IP。

??server_name:

??如果多個 server 的 listen IP 和端口號一模一樣, Nginx 通過請求頭中的 Host

??與 server_name 定義的主機名進行比較,來選擇合適的虛擬服務器處理請求:

??server{

??listen80;

??server_namelufficc.comwww.lufficc.com;

??...

??}

??server_name 的參數可以為:

??1、完整的主機名,如:api.lufficc.com 。

??2、含有通配符(含有 *),如:*.lufficc.com 或 api.* 。

??3、正則表達式,以 ~ 開頭。

??通配符只能在開頭或結尾,而且只能與一個 . 相鄰。www.*.example.org 和 w*.example.org均無效。 但是,可以使用正則表達式匹配這些名稱,例如 ~^www\..+\.example\.org$ 和~^w.*\.example\.org$ 。 而且 * 可以匹配多個部分。 名稱 * .example.org 不僅匹配www.example.org,還匹配www.sub.example.org。

??對于正則表達式:Nginx 使用的正則表達式與 Perl 編程語言(PCRE)使用的正則表達式兼容。 要使用正則表達式,且必須以 ~ 開頭。

??命名的正則表達式可以捕獲變量,然后使用:

??server{

??server_name~^(www\.)?(?.+)$;

??location/{

??root/sites/$domain;

??}

??}

??小括號 () 之間匹配的內容,也可以在后面通過 $1 來引用,$2 表示的是前面第二個 () 里的內容。因此上述內容也可寫為:

??server{

??server_name~^(www\.)?(.+)$;

??location/{

??root/sites/$2;

??}

??}

??一個 server_name 示例:

??server{

??listen80;

??server_nameapi.lufficc.com*.lufficc.com;

??...

??}

??同樣,如果多個名稱匹配 Host 頭部, Nginx 采用下列順序選擇:

??1、完整的主機名,如 api.lufficc.com。

??2、最長的,且以 * 開頭的通配名,如:*.lufficc.com。

??3、最長的,且以 * 結尾的通配名,如:api.* 。

??4、第一個匹配的正則表達式。(按照配置文件中的順序)

??即優先級:api.lufficc.com > *.lufficc.com > api.* > 正則。

??如果 Host 頭部不匹配任何一個 server_name ,Nginx 將請求路由到默認虛擬服務器。默認虛擬服務器是指:nginx.conf 文件中第一個 server 或者 顯式用 default_server 聲明:

??server{

??listen80default_server;

??...

??}

??二、配置 location

??URI 與 location 參數的匹配

??當選擇好 server 之后,Nginx 會根據 URIs 選擇合適的 location 來決定代理請求或者返回文件。

??location 指令接受兩種類型的參數:

??1、前綴字符串(路徑名稱)

??2、正則表達式

??對于前綴字符串參數, URIs 必須嚴格的以它開頭。例如對于 /some/path/ 參數,可以匹配/some/path/document.html ,但是不匹配 /my-site/some/path,因為 /my-site/some/path 不以/some/path/ 開頭。

??server{

??listen80default_server;

??...

??}

??對于正則表達式,以 ~ 開頭表示大小寫敏感,以 ~* 開頭表示大小寫不敏感。注意路徑中的 . 要寫成 \. 。例如一個匹配以 .html 或者 .htm 結尾的 URI 的 location:

??location~\.html?{

??...

??}

??正則表達式的優先級大于前綴字符串。如果找到匹配的前綴字符串,仍繼續搜索正則表達式,但如果前綴字符串以 ^~ 開頭,則不再檢查正則表達式。

??三、具體的搜索匹配流程如下:

??1、將 URI 與所有的前綴字符串進行比較。

??2、= 修飾符表明 URI 必須與前綴字符串相等(不是開始,而是相等),如果找到,則搜索停止。

??3、如果找到的最長前綴匹配字符串以 ^~ 開頭,則不再搜索正則表達式是否匹配。

??4、存儲匹配的最長前綴字符串。

??5、測試對比 URI 與正則表達式。

??6、找到第一個匹配的正則表達式后停止。

??7、如果沒有正則表達式匹配,使用 4 存儲的前綴字符串對應的 location。

??= 修飾符擁有最高的優先級。如網站首頁訪問頻繁,我們可以專門定義一個 location 來減少搜索匹配次數(因為搜索到 = 修飾的匹配的 location 將停止搜索),提高速度:

??location=/{

??...

??}

??四、靜態文件和代理

??location 也定義了如何處理匹配的請求:返回靜態文件 或者 交給代理服務器處理。下面的例子中,第一個 location 返回 /data 目錄中的靜態文件,第二個 location 則將請求傳遞給https://lufficc.com 域名的服務器處理:

??server{

??location/images/{

??root/data;

??}

??location/{

??proxy_passhttps://lufficc.com;

??}

??}

??root 指令定義了靜態文件的根目錄,并且和 URI 拼接形成最終的本地文件路徑。如請求/images/example.png,則拼接后返回本地服務器文件 /data/images/example.png 。

??proxy_pass 指令將請求傳遞到 URL 指向的代理服務器。讓后將來自代理服務器的響應轉發給客戶端。 在上面的示例中,所有不以 /images / 開頭的 URI 的請求都將傳遞給代理服務器處理。

??比如我把 proxy_pass 設置為 https://www.baidu.com/,那么訪問 http://search.lufficc.com/ 將得到百度首頁一樣的響應(頁面)(感興趣的童鞋可以自己試一試搜索功能,和百度沒差別呢):

??server{

??listen80;

??server_namesearch.lufficc.com;

??location/{

??proxy_passhttps://www.baidu.com;

??}

??}

??五、使用變量(Variables)

??你可以使用變量來使 Nginx 在不同的請求下采用不同的處理方式。變量是在運行時計算的,用作指令的參數。 變量由 $ 開頭的符號表示。 變量基于 Nginx 的狀態定義信息,例如當前處理的請求的屬性。

??有很多預定義變量,例如核心的 HTTP 變量,你也可以使用 set,map 和 geo 指令定義自定義變量。 大多數變量在運行時計算,并包含與特定請求相關的信息。 例如,$remote_addr 包含客戶端 IP 地址,$uri 保存當前URI值。

??一些常用的變量如下:


??一個簡單的應用就是從 http 重定向到 https 時帶上路徑信息:

??server{

??...

??return301https://lufficc.com$request_uri;

??...

??}

??六、返回特定狀態碼

??如果你的網站上的一些資源永久移除了,最快最簡潔的方法就是使用 return 指令直接返回:

??location/wrong/url{

??return404;

??}

??return 的第一個參數是響應代碼。可選的第二個參數可以是重定向(對應于代碼301,302,303和307)的 URL 或在響應正文中返回的文本。 例如:

??location/permanently/moved/url{

??return301http://www.example.com/moved/here;}

??return 指令可以包含在 location 和 server 上下文中:

??server{

??location/{

??return404;

??}

??}

??或者:

??server{

??...

??return404;

??location/{

??...

??}

??}

??七、錯誤處理

??error_page 命令可以配置特定錯誤碼的錯誤頁面,或者重定向到其他的頁面。下面的示例將在 404 錯誤發生時返回 /404.html 頁面。

??error_page404/404.html;

??error_page 命令定義了如何處理錯誤,因此不會直接返回,而 return 確實會立即返回。當代理服務器或者 Nginx 處理時產生相應的錯誤的代碼,均會返回相應的錯誤頁面。

??在下面的示例中,當 Nginx 找不到頁面時,它將使用代碼301替換代碼404,并將客戶端重定向到http://example.com/new/path.html 。 此配置很有用,比如當客戶端仍嘗試用舊的 URI 訪問頁面時,301代碼通知瀏覽器頁面已永久移除,并且需要自動替換為返回的新地址。

??location/old/path.html{

??error_page404=301http:/example.com/new/path.html;

??}

??八、重寫 URIs

??rewrite 指令可以多次修改請求的 URI。rewrite 的第一個參數是 URI需要匹配的正則表達式,第二個參數是將要替換的 URI。第三個參數可選,指示是否繼續可以重寫或者返回重定向代碼(301或302)。例如:

??location/users/{

??rewrite^/users/(.*)$/show?user=$1break;

??}

??您可以在 server 和 location 上下文中包括多個 rewrite 指令。 Nginx 按照它們發生的順序一個一個地執行指令。 當選擇 server 時,server 中的 rewrite 指令將執行一次。

??在 Nginx 處理一組 rewrite 指令之后,它根據新的 URI 選擇 location 。 如果所選 location 仍舊包含 rewrite 指令,它們將依次執行。 如果 URI 匹配所有,則在處理完所有定義的 rewrite 指令后,搜索新的 location 。

??以下示例將 rewrite 指令與 return 指令結合使用:

??server{

??...

??rewrite^(/download/.*)/media/(.*)\..*$$1/mp3/$2.mp3last;

??rewrite^(/download/.*)/audio/(.*)\..*$$1/mp3/$2.ralast;

??return403;

??...

??}

??諸如 /download/some/media/file 的 URI 被改為 /download/some/mp3/file.mp3 。 由于 last 標志,后續指令(第二個 rewrite 指令和 return 指令)被跳過,但 Nginx 繼續以更改后的 URI 處理請求。 類似地,諸如 /download/some/audio/file 的 URI 被替換為/download/some/mp3/file.ra。 如果 URI 不匹配 rewrite 指令,Nginx 將403 錯誤代碼返回給客戶端。

??last 與 break的區別是:

??last : 在當前 server 或 location 上下文中停止執行 rewrite 指令,但是 Nginx 繼續搜索與重寫的URI匹配的 location,并應用新 location 中的任何 rewrite 指令(這意味著 URI 可能再次改變)。

??break :停止當前上下文中 rewrite 指令的處理,并取消搜索與新 URI 匹配的 location。 不會執行新 location中的 rewrite 指令。小伙伴們要想獲得更多nginx安裝配置的內容,請關注新網!

聲明:免責聲明:本文內容由互聯網用戶自發貢獻自行上傳,本網站不擁有所有權,也不承認相關法律責任。如果您發現本社區中有涉嫌抄襲的內容,請發

送郵件至:operations@xinnet.com進行舉報,并提供相關證據,一經查實,本站將立刻刪除涉嫌侵權內容。本站原創內容未經允許不得轉載,或轉載時

需注明出處:新網idc知識百科

免費咨詢獲取折扣

Loading
主站蜘蛛池模板: 东北女人av| 亚洲精品国偷拍自产在线观看蜜桃 | 免费精品无码av片在线观看 | 国产色午夜婷婷一区二区三区 | 在线播放的av | 久久成人在线视频 | 久久艹综合 | 午夜av成人| 高清国产一区二区三区 | 无码人妻丰满熟妇区五十路在线 | 99久久无码一区人妻a片蜜 | 91一区二区三区四区 | 成av人片一区二区三区久久 | 国产无遮挡裸体美女视频 | 日本高清不卡中文字幕视频 | 老司机在线免费视频 | 成人娱乐网 | 国产猛男猛女超爽免费视频网站 | 少妇粉嫩小泬喷水视频 | 一级片黄色 | 欧美激情福利 | 免费精品国产人妻国语 | 一本色道久久综合狠狠躁篇怎么玩 | 欧美一级片播放 | 性猛交╳xxx乱大交 av中文在线播放 | 欧美性受xxx | 国产成人av片免费 | 粗暴肉开荤高h文农民工免费视频 | 国偷自产一区二区免费视频 | 少妇被粗大的猛烈进出视频 | 一道本在线观看 | 制服丝袜亚洲欧美中文字幕 | 日韩精品久久久久久久白丝 | 国精产品一品二品国精在线观看 | 亚洲热无码av一区二区东京热av | 欧美在线精品一区 | 亚洲欧美中文日韩v在线观看 | 国产亚洲中文日本不卡二区 | 51精品| 国产av中文av无码av狼人 | 国色天香社区视频手机免费 | 无码精品人妻一区二区三区98 | 亚洲熟伦熟女新五十路熟妇 | 国产精品白浆无码流出 | 久久久久久久久久久久网站 | 性瘾荡乳h古代 | 四虎少妇做爰免费视频网站四 | 国产av老师丝袜美腿丝袜 | 国产成人无码3000部 | 国产肉体xxxx裸体784大胆 | 国产精品99久久精品爆乳 | 中文字幕人成人乱码亚洲影视的特点 | 欧美搡bbbbb搡bbbbb| 欧美性做爰猛烈叫床潮 | 无套熟女av呻吟在线观看 | 亚洲一区在线日韩在线秋葵 | 亚洲第一页在线观看 | 中国人妻被两个老外三p | 中文无码乱人伦中文视频在线v | 永久免费精品精品永久-夜色 | 天天躁日日躁狠狠躁av麻豆男男 | 丰满人妻一区二区三区视频53 | 免费毛片a线观看 | 黄色大片一区二区三区 | 国产精品18久久久久久久久 | 与子乱对白在线播放单亲国产 | 欧美精品一区二区三区四区在线 | 99re热这里只有精品最新 | 亚洲天堂av在线播放 | 亚洲一区二区三区av无码 | avav国产| 无码成a毛片免费 | 无尺码精品产品视频 | 国产欧美视频综合二区 | 91资源在线播放 | 日韩在线一区二区三区免费视频 | 国产精品一品二区三区四区五区 | 一个人看的www视频在线观看 | 亚洲精品自在在线观看 | 高清毛茸茸的中国少妇 | 亚洲美女色视频 | 久久电影网午夜鲁丝片免费 | 99国产精品久久久久久久 | 一区二区精品久久 | 精品一区二区三区不卡 | 一区二区av在线 | 久久视频这里只有精品在线观看 | 一本一道久久a久久 | 国产精品久久成人网站 | 中文字幕一精品亚洲无线一区 | 久久久精品欧美一区二区 | 亚洲香蕉成人av网站在线观看 | 国产亚洲精品久久久久久久久久久久 | 神马久久久久久久久 | 伊人中文字幕无码专区 | 波多野结衣三区 | 男人爱看的网站 | 亚州性无码不卡免费视频 | 久久国产福利播放 |