一篇讓你搞懂 Nginx
目錄
1.Nginx知識網(wǎng)結(jié)構(gòu)圖
1.1反向代理
1.2負(fù)載均衡
1.3動靜分離
2. nginx如何在linux安裝
3. nginx常用命令
4.nginx的配置文件
4.1 反向代理實戰(zhàn)
4.2 反向代理小結(jié)
4.3 負(fù)載均衡實戰(zhàn)
4.4 動靜分離實戰(zhàn)
5.nginx高可用
5.1安裝keepalived
6.原理解析
小結(jié)
目錄
1.Nginx知識網(wǎng)結(jié)構(gòu)圖
1.1反向代理
1.2負(fù)載均衡
1.3動靜分離
2. nginx如何在linux安裝
3. nginx常用命令
4.nginx的配置文件
4.1 反向代理實戰(zhàn)
4.2 反向代理小結(jié)
4.3 負(fù)載均衡實戰(zhàn)
4.4 動靜分離實戰(zhàn)
5.nginx高可用
5.1安裝keepalived
6.原理解析
小結(jié)
Nginx 是一個高性能的 HTTP 和反向代理服務(wù)器,特點是占用內(nèi)存少,并發(fā)能力強(qiáng),事實上 Nginx 的并發(fā)能力確實在同類型的網(wǎng)頁服務(wù)器中表現(xiàn)較好。
Nginx 知識網(wǎng)結(jié)構(gòu)圖
Nginx 的知識網(wǎng)結(jié)構(gòu)圖如下:

反向代理
正向代理:局域網(wǎng)中的電腦用戶想要直接訪問網(wǎng)絡(luò)是不可行的,只能通過代理服務(wù)器來訪問,這種代理服務(wù)就被稱為正向代理。

反向代理:客戶端無法感知代理,因為客戶端訪問網(wǎng)絡(luò)不需要配置,只要把請求發(fā)送到反向代理服務(wù)器,由反向代理服務(wù)器去選擇目標(biāo)服務(wù)器獲取數(shù)據(jù),然后再返回到客戶端。
此時反向代理服務(wù)器和目標(biāo)服務(wù)器對外就是一個服務(wù)器,暴露的是代理服務(wù)器地址,隱藏了真實服務(wù)器 IP 地址。

負(fù)載均衡
客戶端發(fā)送多個請求到服務(wù)器,服務(wù)器處理請求,有一些可能要與數(shù)據(jù)庫進(jìn)行交互,服務(wù)器處理完畢之后,再將結(jié)果返回給客戶端。
普通請求和響應(yīng)過程如下圖:

但是隨著信息數(shù)量增長,訪問量和數(shù)據(jù)量飛速增長,普通架構(gòu)無法滿足現(xiàn)在的需求。
我們首先想到的是升級服務(wù)器配置,可以由于摩爾定律的日益失效,單純從硬件提升性能已經(jīng)逐漸不可取了,怎么解決這種需求呢?
我們可以增加服務(wù)器的數(shù)量,構(gòu)建集群,將請求分發(fā)到各個服務(wù)器上,將原來請求集中到單個服務(wù)器的情況改為請求分發(fā)到多個服務(wù)器,也就是我們說的負(fù)載均衡。
圖解負(fù)載均衡:

假設(shè)有 15 個請求發(fā)送到代理服務(wù)器,那么由代理服務(wù)器根據(jù)服務(wù)器數(shù)量,平均分配,每個服務(wù)器處理 5 個請求,這個過程就叫做負(fù)載均衡。
我把 Ngixn 相關(guān)的文章整理成了 PDF,關(guān)注微信公眾號 Java后端, 回復(fù) 666 下載。
動靜分離
為了加快網(wǎng)站的解析速度,可以把動態(tài)頁面和靜態(tài)頁面交給不同的服務(wù)器來解析,加快解析的速度,降低由單個服務(wù)器的壓力。
動靜分離之前的狀態(tài):

動靜分離之后:

安裝
參考鏈接:
https://blog.csdn.net/yujing1314/article/details/97267369Nginx 常用命令
查看版本:
./nginx -v啟動:
./nginx關(guān)閉(有兩種方式,推薦使用 ./nginx -s quit):
./nginx -s stop
./nginx -s quit重新加載 Nginx 配置:
./nginx -s reloadNginx 的配置文件
配置文件分三部分組成:
①全局塊
從配置文件開始到 events 塊之間,主要是設(shè)置一些影響 Nginx 服務(wù)器整體運行的配置指令。
并發(fā)處理服務(wù)的配置,值越大,可以支持的并發(fā)處理量越多,但是會受到硬件、軟件等設(shè)備的制約。

②events 塊
影響 Nginx 服務(wù)器與用戶的網(wǎng)絡(luò)連接,常用的設(shè)置包括是否開啟對多 workprocess 下的網(wǎng)絡(luò)連接進(jìn)行序列化,是否允許同時接收多個網(wǎng)絡(luò)連接等等。
支持的最大連接數(shù):

③HTTP 塊
諸如反向代理和負(fù)載均衡都在此配置。
location[ = | ~ | ~* | ^~] url{
}location 指令說明,該語法用來匹配 url,語法如上:
=:用于不含正則表達(dá)式的 url 前,要求字符串與 url 嚴(yán)格匹配,匹配成功就停止向下搜索并處理請求。
~:用于表示 url 包含正則表達(dá)式,并且區(qū)分大小寫。
~*:用于表示 url 包含正則表達(dá)式,并且不區(qū)分大小寫。
^~:用于不含正則表達(dá)式的 url 前,要求 Nginx 服務(wù)器找到表示 url 和字符串匹配度最高的 location 后,立即使用此 location 處理請求,而不再匹配。
如果有 url 包含正則表達(dá)式,不需要有 ~ 開頭標(biāo)識。
反向代理實戰(zhàn)
①配置反向代理
目的:在瀏覽器地址欄輸入地址 www.123.com 跳轉(zhuǎn) Linux 系統(tǒng) Tomcat 主頁面。
②具體實現(xiàn)
先配置 Tomcat,因為比較簡單,此處不再贅敘,并在 Windows 訪問:
具體流程如下圖:

修改之前:

配置如下:

再次訪問:

③反向代理 2
目標(biāo):
訪問 http://192.168.25.132:9001/edu/ 直接跳轉(zhuǎn)到 192.168.25.132:8080
訪問 http://192.168.25.132:9001/vod/ 直接跳轉(zhuǎn)到 192.168.25.132:8081
準(zhǔn)備:配置兩個 Tomcat,端口分別為 8080 和 8081,都可以訪問,端口修改配置文件即可。


新建文件內(nèi)容分別添加 8080!!!和 8081!!!


反向代理小結(jié)
第一個例子:瀏覽器訪問 www.123.com,由 host 文件解析出服務(wù)器 ip 地址
192.168.25.132 www.123.com。
然后默認(rèn)訪問 80 端口,而通過 Nginx 監(jiān)聽 80 端口代理到本地的 8080 端口上,從而實現(xiàn)了訪問 www.123.com,最終轉(zhuǎn)發(fā)到 tomcat 8080 上去。
第二個例子:
訪問 http://192.168.25.132:9001/edu/ 直接跳轉(zhuǎn)到 192.168.25.132:8080
訪問 http://192.168.25.132:9001/vod/ 直接跳轉(zhuǎn)到 192.168.25.132:8081
實際上就是通過 Nginx 監(jiān)聽 9001 端口,然后通過正則表達(dá)式選擇轉(zhuǎn)發(fā)到 8080 還是 8081 的 Tomcat 上去。
負(fù)載均衡實戰(zhàn)
①修改 nginx.conf,如下圖:


②重啟 Nginx:
./nginx -s reload③在 8081 的 Tomcat 的 webapps 文件夾下新建 edu 文件夾和 a.html 文件,填寫內(nèi)容為 8081!!!!
④在地址欄回車,就會分發(fā)到不同的 Tomcat 服務(wù)器上:


負(fù)載均衡方式如下:
輪詢(默認(rèn))。
weight,代表權(quán),權(quán)越高優(yōu)先級越高。
fair,按后端服務(wù)器的響應(yīng)時間來分配請求,相應(yīng)時間短的優(yōu)先分配。
ip_hash,每個請求按照訪問 ip 的 hash 結(jié)果分配,這樣每一個訪客固定的訪問一個后端服務(wù)器,可以解決 Session 的問題。
動靜分離實戰(zhàn)
什么是動靜分離?把動態(tài)請求和靜態(tài)請求分開,不是講動態(tài)頁面和靜態(tài)頁面物理分離,可以理解為 Nginx 處理靜態(tài)頁面,Tomcat 處理動態(tài)頁面。
動靜分離大致分為兩種:
純粹將靜態(tài)文件獨立成單獨域名放在獨立的服務(wù)器上,也是目前主流方案。
將動態(tài)跟靜態(tài)文件混合在一起發(fā)布,通過 Nginx 分開。
動靜分離圖析:

實戰(zhàn)準(zhǔn)備,準(zhǔn)備靜態(tài)文件:


配置 Nginx,如下圖:

Nginx 高可用
如果 Nginx 出現(xiàn)問題:

解決辦法:

前期準(zhǔn)備:
兩臺 Nginx 服務(wù)器
安裝 Keepalived
虛擬 ip
安裝 Keepalived:
[root@192 usr]# yum install keepalived -y
[root@192 usr]# rpm -q -a keepalived
keepalived-1.3.5-16.el7.x86_64修改配置文件:
[root@192 keepalived]# cd /etc/keepalived
[root@192 keepalived]# vi keepalived.conf分別將如下配置文件復(fù)制粘貼,覆蓋掉 keepalived.conf,虛擬 ip 為 192.168.25.50。
對應(yīng)主機(jī) ip 需要修改的是:
smtp_server 192.168.25.147(主)smtp_server 192.168.25.147(備)
state MASTER(主) state BACKUP(備)
global_defs {notification_email {[email protected][email protected][email protected]}notification_email_from [email protected]smtp_server 192.168.25.147smtp_connect_timeout 30router_id LVS_DEVEL # 訪問的主機(jī)地址}vrrp_script chk_nginx {script "/usr/local/src/nginx_check.sh" # 檢測文件的地址interval 2 # 檢測腳本執(zhí)行的間隔weight 2 # 權(quán)重}vrrp_instance VI_1 {state BACKUP # 主機(jī)MASTER、備機(jī)BACKUPinterface ens33 # 網(wǎng)卡virtual_router_id 51 # 同一組需一致priority 90 # 訪問優(yōu)先級,主機(jī)值較大,備機(jī)較小advert_int 1authentication {auth_type PASSauth_pass 1111}virtual_ipaddress {192.168.25.50 # 虛擬ip}}
啟動命令如下:
[root@192 sbin]# systemctl start keepalived.service訪問虛擬 ip 成功:

關(guān)閉主機(jī) 147 的 Nginx 和 Keepalived,發(fā)現(xiàn)仍然可以訪問。
原理解析



小結(jié)
作者:漸暖°
來源:blog.csdn.net/yujing1314/article/details/107000737
版權(quán)申明:內(nèi)容來源網(wǎng)絡(luò),版權(quán)歸原創(chuàng)者所有。如有侵權(quán)煩請告知,我們會立即刪除。謝謝!

