寫給前端的Nginx入門指南
點擊上方?前端Q,關注公眾號
回復加群,加入前端Q技術交流群
這份指南是對nginx的基本介紹,描述了用戶借助nginx可以實現(xiàn)的一些簡單任務。只支持運行在已經(jīng)安裝了nginx的讀者機器上;如果沒有安裝,請參考Installing nginx 頁面。
這份指南描述了怎樣啟動和停止nginx以及重新加載配置,說明了配置文件的結構以及如何啟動nginx以輸出靜態(tài)內容,怎樣設置代理服務器 和怎樣連接FastCGI應用。
nginx有一個主進程和幾個工作進程。主進程的主要目的是為了讀取和評估配置并且維護工作進程。工作進程處理實際請求。nginx在工作進程中采用事件驅動模型和OS依賴機制有效分配請求。工作進程的數(shù)量取決于配置文件中定義的固定值或者是通過有效的CPU核數(shù)自動判定數(shù)量。工作進程的數(shù)量在配置文件中定義,可據(jù)給定的配置對工作進程的數(shù)量進行固定,也可以根據(jù)可用CPU內核的數(shù)量進行自動調整。(參看 worker_processes).
nginx及其各模塊的工作方式取決于配置文件。默認情況下,配置文件名為nginx.conf,并放置在/usr/local/nginx/conf、/etc/nginx或/usr/local/etc/nginx.目錄中。
啟動, 停止, 和重新加載配置文件
啟動的時候直接運行nginx.exe或者nginx。如果nginx已經(jīng)啟動,就可以直接使用參數(shù)-s 來進行調用執(zhí)行,具體的使用語法如下:
nginx?-s?signal
signal 的位置可以是如下參數(shù):
stop —指令一經(jīng)發(fā)出,直接停止
quit — 等待所有的請求完成,再停止
reload — 重新加載配置文件nginx.conf
reopen —重新打開日志文件
例如,想要停止nginx進程,(等待當前所有的請求進程全部完成),可以使用如下命令:
nginx?-s?quit
注:此命令應在啟動nginx的同一用戶下執(zhí)行。
reload或重啟nginx,修改的配置文件才會被應用。為了重新加載配置,執(zhí)行如下命令:
nginx?-s?reload
一旦主進程收到reload的信號,它就會檢查新的配置文件語法,并且嘗試應用這個新的配置文件。如果執(zhí)行成功,主進程會啟用一個新的工作進程,然后給原來工作進程發(fā)送一個信號,讓它原來的工作進程停止。如果執(zhí)行失敗,主進程會回滾到原來的配置文件并繼續(xù)使用原來的配置文件進行執(zhí)行。原來的工作進程接收到停止命令之后,它會停止新的連接請求,但是當前已經(jīng)建立的連接請求會等待其完成后終止。之后舊進程就會退出。
可以借助Unix工具(如kill實用程序)將信號發(fā)送到nginx進程。在這種情況下,信號直接發(fā)送到具有給定進程ID的進程。這個進程ID就是nginx的主進程標記,同時這個進程ID會被默認寫入到文件夾/usr/local/nginx/logs或者/var/run下面。例如:如果主進程ID是1628,就發(fā)送指令QUIT來正常停止nginx,執(zhí)行下面命令:
kill?-s?QUIT?1628
為了得到正在運行的ngixn進程列表,可以通過ps指令得到:
ps?-ax?|?grep?nginx
獲取更多nginx信號信息,參考 Controlling nginx.
配置文件結構
nginx由模塊組成,這些模塊由配置文件中指定的指令控制。指令分為簡單指令和塊指令。一個簡單的指令由名稱和參數(shù)組成,這些名稱和參數(shù)由空格分隔,并以分號(;)結尾。塊指令具有與簡單指令相同的結構,但它的結尾不是分號,而是一組由大括號({、})包圍的附加指令。如果一個塊指令在大括號中包含其他指令,則這個塊指令又叫做上下文 (例如: events, http, server, 和location).
放在任何上下文之外的配置文件中的指令被認為是在主上下文 中。event和http指令駐留在主上下文中,server駐留在http中,location駐留在server中。
一行中在#符號后面的是注釋
提供靜態(tài)資源內容
web服務器最重要的任務是對外提供文件,例如(圖片或者靜態(tài)HTML網(wǎng)頁)。示例:不同的請求會響應到不同的文件夾路徑: /data/www(包含靜態(tài)HTML文件) /data/images (包含圖片)。此過程需要編輯配置文件,并在附有兩個location塊的http塊中設置server塊。參考:server指令 http指令 location 指令
首先,創(chuàng)建一個文件夾/data/www 把有內容的index.html 文件放到里面。并且創(chuàng)建/data/images文件夾,在里面放一些圖片。
第二步,打開配置文件。默認的配置文件已經(jīng)包含了幾個server塊指令,但是被注釋了,現(xiàn)在把這些server塊指令放開注釋。
http?{
??server?{
??}
}
通常,配置文件包含幾個server塊指令,這些塊指令通過不同的服務名字(server names)分發(fā)監(jiān)聽(distinguished listen)在不同的端口。一旦nginx決定哪個服務器處理請求,它就會根據(jù)server塊指令中定義的location指令的參數(shù)匹配請求頭中指定的URI。
在server塊指令中添加location指令:
location?/?{
??root?/data/www;
}
這個location塊詳述了與URI請求相匹配的“/”前綴。如果匹配到請求,這個 URI 會被轉到 root 指令的路徑。,也就是說,所有請求文件都會直接請求到本地文件系統(tǒng)的/data/www路徑。如果有多個匹配的location塊,nginx會選擇最長前綴的那個。上面提供的location塊是長度只有1的最短前綴,因此,其它所有的location塊都匹配失敗的話,這個location塊指令才會被使用。
下一步,添加第二個location塊:
location?/images/?{
??root?/data;
}
這個會匹配以/images開頭的請求(/也會匹配請求,只不過這個前綴更短)。
server塊指令配置結果如下:
server?{
??location?/?{
????root?/data/www;
??}
??location?/images/?{
????root?/data;
??}
}
一個正常的服務器配置文件監(jiān)聽在80端口上,并且可以在本機上成功訪問http://localhost/。以/images/開頭請求的URI地址,服務器會從/data/images文件夾下面返回對應的文件。例如,請求/data/images/example.png這個文件,nginx服務器會返回http://localhost/images/example.png。如果服務器沒有這個文件會返回404 錯誤。不是以/images/開頭的請求,就會被映射到/data/www 文件夾。例如, 請求nginx/data/www/some/example.html,服務器會響應http://localhost/some/example.html 這個文件。
為了應用一個新的配置文件,如果nginx還沒有啟動,就直接啟動nginx服務器,如果已經(jīng)啟動,直接使用下面指令發(fā)送到nginx的主進程中,如下: 如果nginx尚未啟動,則啟動nginx,或者向nginx的主進程發(fā)送重新加載信號,執(zhí)行:
nginx?-s?reload
一些情況下(?***),沒有達到預期的效果,你可以嘗試通過查看access.log和 error.log (通常在/usr/local/nginx/logs或者/var/log/nginx) 日志文件來找原因。
設置一個簡單的代理服務器 使用最頻繁的是設置一個代理服務器,也即接受請求,并把所有的請求轉到被代理的服務器上,獲取到響應之后再發(fā)送到客戶端。
我們能配置一個基本的代理服務器,它的 ***圖片文件請求和其它的全部請求都會被發(fā)送到代理服務器上。本例中,兩個服務器定義在一個nginx實例。
首先,通過在配置文件中添加server塊指令的方式來定義一個代理服務器。
server?{
??listen?8080;
??root?/data/up1;
??location?/?{}
}
這個簡單的服務器會監(jiān)聽8080端口(之前, 由于使用了標準端口80,因此尚未指定listen指令)并且映射所有的請求到本地文件系統(tǒng)的/data/up1文件夾。創(chuàng)建這個文件夾并放一個文件index.html。需要注意的是 server上下文就是這個根指令的位置。例如 當選擇用于提供請求的location塊指令不包括根指令時,使用這樣的根指令(root /data/up1)。
接下來,使用上一節(jié)中的服務器配置,并將其修改為代理服務器配置。在第一個位置塊中,使用參數(shù)中指定的代理服務器的協(xié)議、名稱和端口(在我們的示例中,它是[http://localhost:8080)放置proxy](http://localhost:8080)放置proxy_pass指令:
server?{
??location?/?{
????proxy_pass?http://localhost:8080;
??}
??location?/images/?{
????root?/data;
??}
}
我們修改第二個location指令塊,這個指令塊會把當前的/images前綴請求映射到/data/images文件夾中,為了匹配更多的圖片類型請求,location塊指令修改如下:
location?~?\.(gif|jpg|png)$?{
??root?/data/images;
}
使用正則表達式~來匹配所有以 .gif, .jpg, 和.png結尾的URIs,響應的請求會被映射到/data/images文件夾中。
nginx在匹配location請求的時候,首先檢查location 指令的特殊前綴,最長前綴(),最后檢查正則。如果這個請求匹配到正則,ngixn會選中這個location,否則,會跳過找到最前的一個()。
代理服務器的配置結果看起來就是這樣子:
server?{
??location?/?{
????proxy_pass?http://localhost:8080/;
??}
??location?~?\.(gif|jpg|png)$?{
????root?/data/images;
??}
}
這個服務器將會過濾后綴為 .gif, .jpg, 或者 .png 的然后分發(fā)到/data/images文件夾(通過在root中添加URI參數(shù)) ,并且其它的請求會被代理到上面的server配置()中http://localhost:8080/。
為了使用最新的配置,就像前面一樣,向nginx發(fā)送一個reload信號。
這里有更多的 more 指令可以使用在代理連接配置中。
啟用 FastCGI 代理 nginx也能把請求路由到FastCGI服務上,它運行程序使用各種框架和編程語言(如PHP)。
使用FastCGI服務器的最基本的nginx配置包括使用fastcgipass 指令而不是proxypass指令,以及fastcgiparam指令來設置傳遞給FastCGI服務器的參數(shù)。假設FastCGI服務在localhost:9000可以訪問,以上面一部分的配置為基礎,替換proxypass指令為fastcgipass,并且修改參數(shù)為 localhost:9000。在PHP中, SCRIPTFILENAME參數(shù)為定義的腳本名稱 QUERY_STRING參數(shù)為被請求的參數(shù)**,最終的配置如下:
server?{
??location?/?{
????fastcgi_pass??localhost:9000;
????fastcgi_param?SCRIPT_FILENAME?$document_root$fastcgi_script_name;
????fastcgi_param?QUERY_STRING????$query_string;
??}
??location?~?\.(gif|jpg|png)$?{
????root?/data/images;
??}
}
這個服務器設置會路由所有除了靜態(tài)圖片的請求,通過FastCGI協(xié)議代理到localhost:9090代理服務器上。
譯自:https://www.zcfy.cc/article/nginx-beginner-s-guide

往期推薦



歡迎加我微信,拉你進技術群,長期交流學習...
歡迎關注「前端Q」,認真學前端,做個專業(yè)的技術人...


