真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

怎么將Nginx配置為Web服務(wù)器

本篇內(nèi)容主要講解“怎么將Nginx配置為Web服務(wù)器”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實(shí)用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“怎么將Nginx配置為Web服務(wù)器”吧!

十年的武鄉(xiāng)網(wǎng)站建設(shè)經(jīng)驗,針對設(shè)計、前端、開發(fā)、售后、文案、推廣等六對一服務(wù),響應(yīng)快,48小時及時工作處理。全網(wǎng)整合營銷推廣的優(yōu)勢是能夠根據(jù)用戶設(shè)備顯示端的尺寸不同,自動調(diào)整武鄉(xiāng)建站的顯示方式,使網(wǎng)站能夠適用不同顯示終端,在瀏覽器中調(diào)整網(wǎng)站的寬度,無論在任何一種瀏覽器上瀏覽網(wǎng)站,都能展現(xiàn)優(yōu)雅布局與設(shè)計,從而大程度地提升瀏覽體驗。成都創(chuàng)新互聯(lián)從事“武鄉(xiāng)網(wǎng)站設(shè)計”,“武鄉(xiāng)網(wǎng)站推廣”以來,每個客戶項目都認(rèn)真落實(shí)執(zhí)行。

抽象來說,將 Nginx 配置為 Web 服務(wù)器就是定義處理哪些 URLS 和如何處理這些URLS  對應(yīng)的請求。具體來說,就是定義一些虛擬服務(wù)器(Virtual Servers),控制具有特定 IP 和域名的請求。

更具體的來說, Nginx 通過定義一系列 locations 來控制對 URIS 的選擇。每一個 location  定義了對映射到自己的請求的處理場景:返回一個文件或者代理請求,或者根據(jù)不同的錯誤代碼返回不同的錯誤頁面。另外,根據(jù) URI 的不同,請求也可以被重定向到其它  server 或者 location 。

設(shè)置虛擬服務(wù)器

listen:

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

虛擬服務(wù)器定義在 http 上下文中的 server 中:

http {        server {            # Server configuration        }    }

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

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

server {        listen 127.0.0.1:8080;  # IPv4地址,8080端口        # listen [2001:3CA1:10F:1A:121B:0:0:10]:80;   # IPv6地址,80端口        # listen [::]:80;  # 聽本機(jī)的所有IPv4與IPv6地址,80端口        # The rest of server configuration    }

上述配置,如果不寫端口號,默認(rèn)使用80端口,如果不寫 IP ,則監(jiān)聽本機(jī)所有 IP。

server_name:

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

怎么將Nginx配置為Web服務(wù)器

與 server_name 定義的主機(jī)名進(jìn)行比較,來選擇合適的虛擬服務(wù)器處理請求:

server {        listen      80;        server_name lufficc.com  www.lufficc.com;        ...    }

server_name 的參數(shù)可以為:

1、完整的主機(jī)名,如:api.lufficc.com 。

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

3、正則表達(dá)式,以 ~ 開頭。

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

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

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

server {        server_name   ~^(www\.)?(?.+)$;         location / {            root   /sites/$domain;        }    }

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

server {        server_name   ~^(www\.)?(.+)$;         location / {            root   /sites/$2;        }    }

一個 server_name 示例:

server {        listen      80;        server_name api.lufficc.com  *.lufficc.com;        ...    }

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

1、完整的主機(jī)名,如 api.lufficc.com。

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

3、最長的,且以 * 結(jié)尾的通配名,如:api.* 。

4、***個匹配的正則表達(dá)式。(按照配置文件中的順序)

即優(yōu)先級:api.lufficc.com > *.lufficc.com > api.* > 正則。

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

server {        listen      80 default_server;        ...    }

配置 location

URI 與 location 參數(shù)的匹配

當(dāng)選擇好 server 之后,Nginx 會根據(jù) URIs 選擇合適的 location 來決定代理請求或者返回文件。

location 指令接受兩種類型的參數(shù):

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

2、正則表達(dá)式

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

server {        listen      80 default_server;        ...    }

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

location ~ \.html? {        ...    }

正則表達(dá)式的優(yōu)先級大于前綴字符串。如果找到匹配的前綴字符串,仍繼續(xù)搜索正則表達(dá)式,但如果前綴字符串以 ^~ 開頭,則不再檢查正則表達(dá)式。

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

1、將 URI 與所有的前綴字符串進(jìn)行比較。

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

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

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

5、測試對比 URI 與正則表達(dá)式。

6、找到***個匹配的正則表達(dá)式后停止。

7、如果沒有正則表達(dá)式匹配,使用 4 存儲的前綴字符串對應(yīng)的 location。

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

location = / {        ...    }

靜態(tài)文件和代理

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

server {        location /images/ {            root /data;        }         location / {            proxy_pass https://lufficc.com;        }    }

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

proxy_pass 指令將請求傳遞到 URL 指向的代理服務(wù)器。讓后將來自代理服務(wù)器的響應(yīng)轉(zhuǎn)發(fā)給客戶端。 在上面的示例中,所有不以 /images /  開頭的 URI 的請求都將傳遞給代理服務(wù)器處理。

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

server{          listen 80;          server_name search.lufficc.com;          location / {                  proxy_pass https://www.baidu.com;          }    }

使用變量(Variables)

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

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

一些常用的變量如下:

怎么將Nginx配置為Web服務(wù)器

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

server{           ...           return      301 https://lufficc.com$request_uri;           ...    }

返回特定狀態(tài)碼

如果你的網(wǎng)站上的一些資源***移除了,最快最簡潔的方法就是使用 return 指令直接返回:

location /wrong/url {        return 404;    }

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

location /permanently/moved/url {        return 301 http://www.example.com/moved/here;   }

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

server{             location / {                     return 404;             }       }

或者:

server{          ...          return 404;          location / {              ...                      }    }

錯誤處理

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

error_page 404 /404.html;

error_page 命令定義了如何處理錯誤,因此不會直接返回,而 return 確實(shí)會立即返回。當(dāng)代理服務(wù)器或者 Nginx  處理時產(chǎn)生相應(yīng)的錯誤的代碼,均會返回相應(yīng)的錯誤頁面。

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

location /old/path.html {        error_page 404 =301 http:/example.com/new/path.html;    }

重寫 URIs

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

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

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

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

以下示例將 rewrite 指令與 return 指令結(jié)合使用:

server {        ...        rewrite ^(/download/.*)/media/(.*)\..*$ $1/mp3/$2.mp3 last;        rewrite ^(/download/.*)/audio/(.*)\..*$ $1/mp3/$2.ra  last;        return  403;        ...    }

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

last 與 break的區(qū)別是:

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

  • break :停止當(dāng)前上下文中 rewrite 指令的處理,并取消搜索與新 URI 匹配的 location。 不會執(zhí)行新 location中的  rewrite 指令。

附錄

常用正則

  • : 匹配除換行符以外的任意字符

  • ? : 重復(fù)0次或1次

  • + : 重復(fù)1次或更多次

  • *: 重復(fù)0次或更多次

  • \d :匹配數(shù)字

  • ^ : 匹配字符串的開始

  • $ : 匹配字符串的結(jié)束

  • {n} : 重復(fù)n次

  • {n,} : 重復(fù)n次或更多次

  • [c] : 匹配單個字符c

  • [a-z]: 匹配a-z小寫字母的任意一個

全局變量

  • $args : #這個變量等于請求行中的參數(shù),同$query_string

  • $content_length : 請求頭中的Content-length字段。

  • $content_type : 請求頭中的Content-Type字段。

  • $document_root : 當(dāng)前請求在root指令中指定的值。

  • $host : 請求主機(jī)頭字段,否則為服務(wù)器名稱。

  • $http_user_agent : 客戶端agent信息

  • $http_cookie : 客戶端cookie信息

  • $limit_rate : 這個變量可以限制連接速率。

  • $request_method : 客戶端請求的動作,通常為GET或POST。

  • $remote_addr : 客戶端的IP地址。

  • $remote_port : 客戶端的端口。

  • $remote_user : 已經(jīng)經(jīng)過Auth Basic Module驗證的用戶名。

  • $request_filename : 當(dāng)前請求的文件路徑,由root或alias指令與URI請求生成。

  • $scheme : HTTP方法(如http,https)。

  • $server_protocol : 請求使用的協(xié)議,通常是HTTP/1.0或HTTP/1.1。

  • $server_addr : 服務(wù)器地址,在完成一次系統(tǒng)調(diào)用后可以確定這個值。

  • $server_name : 服務(wù)器名稱。

  • $server_port : 請求到達(dá)服務(wù)器的端口號。

  • $request_uri : 包含請求參數(shù)的原始URI,不包含主機(jī)名,如:/foo/bar.php?arg=baz。

  • $uri : 不帶請求參數(shù)的當(dāng)前URI,$uri不包含主機(jī)名,如/foo/bar.html。

  • $document_uri : 與$uri相同。

  • 例如請求:http://localhost:88/test1/test2/test.php

  • $host:localhost

  • $server_port:88

  • $request_uri:/test1/test2/test.php

  • $document_uri:/test1/test2/test.php

  • $document_root:/var/www/html

  • $request_filename:/var/www/html/test1/test2/test.php

到此,相信大家對“怎么將Nginx配置為Web服務(wù)器”有了更深的了解,不妨來實(shí)際操作一番吧!這里是創(chuàng)新互聯(lián)網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!


新聞標(biāo)題:怎么將Nginx配置為Web服務(wù)器
當(dāng)前鏈接:http://weahome.cn/article/piisgd.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部