您好,登錄后才能下訂單哦!
這篇文章主要介紹“Nginx如何配置Web服務器”,在日常操作中,相信很多人在Nginx如何配置Web服務器問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”Nginx如何配置Web服務器”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
概述
今天主要分享怎么將NGINX配置作為Web服務器,并包括以下部分:
?設置虛擬服務器
?配置位置
?使用變量
?返回特定狀態碼
?重寫HTTP響應
在高層次上,將NGINX配置作為Web服務器有一些問題需要了解,定義它處理哪些URL以及如何處理這些URL上的資源的HTTP請求。 在較低層次上,配置定義了一組控制對特定域或IP地址的請求的處理的虛擬服務器。
用于HTTP流量的每個虛擬服務器定義了稱為位置的特殊配置實例,它們控制特定URI集合的處理。 每個位置定義了自己的映射到此位置的請求發生的情況。 NGINX可以完全控制這個過程。 每個位置都可以代理請求或返回一個文件。 此外,可以修改URI,以便將請求重定向到另一個位置或虛擬服務器。 此外,可以返回特定的錯誤代碼,也可以配置特定的頁面以對應于每個錯誤代碼。
1. 設置虛擬服務器
NGINX配置文件必須至少包含一個服務器指令來定義虛擬服務器。 當NGINX處理請求時,它首先選擇提供請求的虛擬服務器。
虛擬服務器由http上下文中的服務器指令定義,例如:
http { server { # Server configuration } }
可以將多個server指令添加到http上下文中以定義多個虛擬服務器。
server配置塊通常包括一個listen指令,用于指定服務器偵聽請求的IP地址和端口(或Unix域套接字和路徑)。IPv4和IPv6地址均被接受; 將方括號(。
下面的示例顯示了監聽IP地址127.0.0.1和端口8080的服務器的配置:
server { listen 127.0.0.1:8080; # The rest of server configuration }
如果省略端口,則使用標準端口。 同樣地,如果省略一個地址,服務器將偵聽所有地址。 如果沒有包含listen指令,則“標準”端口為80/tcp,“default”端口為8000/tcp,具體取決于超級用戶權限。
如果有多個服務器與請求的IP地址和端口相匹配,則NGINX將根據服務器塊中的server_name指令測試請求的主機頭域。 server_name的參數可以是完整(精確)名稱,通配符或正則表達式。 通配符是一個字符串,其開頭,結尾或兩者都包含星號(*); 星號匹配任何字符序列。 NGINX將Perl語法用于正則表達式; 在它們之前使用波浪號()。 此示例說明了一個確切的名稱。
server { listen 80; server_name example.org www.example.org; ... }
2. 配置位置
NGINX可以根據請求URI向不同的代理發送流量或提供不同的文件。 這些塊是使用放置在server指令中的location指令來定義的。
例如,您可以定義三個location塊,以指示虛擬服務器向一個代理服務器發送一些請求,將其他請求發送到不同的代理服務器,并通過從本地文件系統傳遞文件來提供其余請求。
NGINX測試根據所有location指令的參數請求URI,并應用匹配location中定義的指令。 在每個location塊內,通常可能(除了一些例外)放置更多的location指令以進一步細化特定組請求的處理。
注意:在本教程文章中,單詞location是指單個location上下文。
location指令有兩種類型的參數:前綴字符串(路徑名)和正則表達式。 對于要匹配前綴字符串的請求URI,必須以前綴字符串開頭。
具有pathname參數的以下示例位置匹配以/some/path/開頭的請求URI,例如/some/path/document.html,它不匹配/my-site/some/path,因為/some/path不在該URI的開頭出現。
location /some/path/ { ... }
正則表達式之前是區分大小寫匹配的波形符號(~),或者不區分大小寫匹配的波形符號(~*)。 以下示例將包含字符串.html或.html的URI與任何位置相匹配。
location ~ \.html? { ... }
要找到最符合URI的位置,NGINX首先將URI與前綴字符串的位置進行比較。然后用正則表達式搜索位置。
location上下文可以包含定義如何解析請求的指令 - 提供靜態文件或將請求傳遞給代理的服務器。 在以下示例中,匹配第一個location上下文的請求將從/data/images目錄中提供文件,并將匹配第二個位置的請求傳遞給承載 www.example.com 域內容的代理服務器。
server { location /images/ { root /data; } location / { proxy_pass http://www.example.com; } }
root指令指定要在其中搜索要提供的靜態文件的文件系統路徑。 與該位置相關聯的請求URI將附加到路徑,以獲取要提供的靜態文件的全名。 在上面的示例中,要響應/images/logo.png的請求,NGINX提供服務器本地實際對應文件是:/data/images/logo.png。
proxy_pass指令將請求傳遞給使用配置的URL訪問代理服務器。然后將代理服務器的響應傳回客戶端。在上面的示例中,所有不以/images/開頭的URI的請求都將被傳遞給代理的服務器(也就是:www.example.com)。
3. 使用變量
可以使用配置文件中的變量,使NGINX進程的請求根據定義的情況而有所不同。 變量是在運行時計算的命名值,用作指令的參數。 一個變量由它的名字開頭的$(美元)符號表示。 變量根據NGINX的狀態定義信息,例如正在處理的請求的屬性。
有許多預定義的變量,如核心HTTP變量,您可以使用set,map和geo指令定義自定義變量。 大多數變量在運行時計算的,并包含與特定請求相關的信息。 例如,$remote_addr包含客戶端IP地址,$uri保存當前的URI值。
4. 返回特定狀態碼
一些網站URI需要立即返回具有特定錯誤或重定向代碼的響應,例如當頁面被暫時移動或永久移動時。 最簡單的方法是使用return指令。 例如返回未找到的404狀態碼:
location /wrong/url { return 404; }
返回的第一個參數是響應代碼。可選的第二個參數可以是重定向的URL(代碼301,302,303和307)或在響應體中返回文本。 例如:
location /permanently/moved/url { return 301 http://www.example.com/moved/here; }
返回指令可以包含在 location 和 server 上下文中。
5. 重寫HTTP響應
有時需要重寫或更改HTTP響應中的內容,將一個字符串替換為另一個字符串。 可以使用sub_filter指令來定義要應用的重寫。 該指令支持變量和替代鏈,使更復雜的更改成為可能。
例如,可以更改引用除代理服務器之外的絕對鏈接:
location / { sub_filter /blog/ /blog-staging/; sub_filter_once off; }
另一個示例將方法從http://更改為http://,并從請求頭域替換本地主機地址到主機名。 sub_filter_once指令告訴NGINX在一個位置(location)內連續應用sub_filter偽指令:
location / { sub_filter 'href="http://127.0.0.1:8080/' 'href="http://$host/'; sub_filter 'img src="https://127.0.0.1:8080/' 'img src="https://$host/'; sub_filter_once on; }
請注意,如果發生另一個sub_filter匹配,則使用sub_filter修改的響應部分將不再被替換。
到此,關于“Nginx如何配置Web服務器”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。