Nginx服務(wù)快速入門教程
一、Nginx介紹
1. 什么是Nginx?
- Nginx (engine x) 是一個(gè)高性能的HTTP和反向代理web服務(wù)器,同時(shí)也提供了IMAP/POP3/SMTP服務(wù)。
- 其特點(diǎn)是占有內(nèi)存少,并發(fā)能力強(qiáng),事實(shí)上nginx的并發(fā)能力在同類型的網(wǎng)頁服務(wù)器中表現(xiàn)較好。
2. 為什么要使用Nginx?
隨著當(dāng)今互聯(lián)網(wǎng)的迅速發(fā)展,單點(diǎn)服務(wù)器早已無法承載上萬個(gè)乃至數(shù)十萬個(gè)用戶的持續(xù)訪問。比如一臺(tái)Tomcat服務(wù)器在理想狀態(tài)下只能夠可以承受住2000個(gè)左右的并發(fā)量,為了解決這個(gè)問題,就需要多臺(tái)Tomcat服務(wù)器來進(jìn)行負(fù)載均衡。
那么,應(yīng)該如何實(shí)現(xiàn)負(fù)載均衡?Nginx就是其中的一種解決方案,當(dāng)用戶訪問網(wǎng)站時(shí),Nginx攔截到這個(gè)訪問請(qǐng)求,并將其通過輪詢的方式均勻地分配到不同的服務(wù)器上。
并且,在Nginx中有一種ip_hash策略,它可以獲取到用戶的真實(shí)IP,計(jì)算出hash值來選擇服務(wù)器,這也是一種優(yōu)秀的負(fù)載均衡方式。 所以,掌握Nginx成為了Web開發(fā)學(xué)習(xí)道路上不可缺少的一部分。
3. 什么是正向代理?
正向代理,就是客戶端將自己的請(qǐng)求率先發(fā)給代理服務(wù)器,通過代理服務(wù)器將請(qǐng)求轉(zhuǎn)發(fā)給服務(wù)器。我們常用的VPN就是一種代理服務(wù)器,為了可以連上國外的網(wǎng)站,客戶端需要使用一個(gè)可以連接外網(wǎng)的服務(wù)器作為代理,并且客戶端能夠連接上該代理服務(wù)器。
4. 什么是反向代理?
反向代理與正向代理不同,正向代理是代理了客戶端,而反向代理則是代理服務(wù)器端。在有多臺(tái)服務(wù)器分布的情況下,為了能讓客戶端訪問到的IP地址都為同一個(gè)網(wǎng)站,就需要使用反向代理。
明白了反向代理的工作機(jī)制后,接下來就可以進(jìn)入Nginx的學(xué)習(xí)!
二、Nginx在Linux下的安裝
由于Nginx被大量使用在Web服務(wù)器中,所以本教程選擇了Centos服務(wù)器的7.4版本作為演示!
1. 下載
進(jìn)入官方下載頁面:http://nginx.org/en/download.html,選擇Stable version穩(wěn)定版本進(jìn)行下載,并上傳至服務(wù)器。
2. 安裝
上傳tar包至服務(wù)器后,解壓到當(dāng)前目錄
tar -zxvf nginx-1.18.0.tar.gz -C ./
進(jìn)入解壓后的目錄,執(zhí)行configure腳本
cd nginx-1.18.0/ ./configure
使用make命令進(jìn)行安裝
make && make install
安裝完成后,使用whereis命令查找Nginx的安裝位置 (默認(rèn)安裝在/user/local/目錄下)
whereis nginx
進(jìn)入安裝目錄下的bin文件夾,啟動(dòng)nginx服務(wù),訪問服務(wù)器默認(rèn)的80端口查看是否安裝成功!
三、Nginx配置入門
1. 配置文件
在Nginx的安裝目錄下有一個(gè)conf文件夾,打開其中的nginx.conf文件
cd conf/ && vim nginx.conf
2. 反向代理單個(gè)服務(wù)器
那么,如何使用Nginx進(jìn)行反向代理?
在location參數(shù)中添加proxy_pass字段,并填寫需要反向代理的服務(wù)器地址與端口號(hào):
注意:每一行的配置都需要以封號(hào)結(jié)尾?。。?/p>
# 配置監(jiān)聽的目錄為:/ location / { root html; index index.html index.htm; proxy_pass http://127.0.0.1:8080; # 反向代理了本機(jī)的8080端口 # proxy_pass http://127.0.0.1:8081; # 可以同時(shí)配置多條proxy_pass,反向代理了本機(jī)的8081端口 }
3. 反向代理多臺(tái)服務(wù)器
如果有多臺(tái)服務(wù)器怎么辦?除了不斷地添加proxy_pass參數(shù),更好的解決方案是配置upstream服務(wù)器組!
在配置文件的http塊中添加upstream屬性:
# 配置服務(wù)器組,取名為hello upstream hello{ # 一個(gè)server對(duì)應(yīng)一個(gè)服務(wù)器,當(dāng)然也可以是不同端口的web程序 server 127.0.0.1:8080; server 127.0.0.1:8081; } # 在location塊中修改反向代理為服務(wù)器組 location / { root html; index index.html index.htm; proxy_pass http://hello; # 反向代理了hello服務(wù)器組中的所有服務(wù)器 }
四、運(yùn)行測(cè)試
1. 啟動(dòng)服務(wù)
配置完成后,進(jìn)入Nginx安裝目錄下的sbin文件夾,運(yùn)行nginx程序即可:
/usr/local/nginx/sbin/nginx
如果之前已經(jīng)啟動(dòng),無需關(guān)閉nginx服務(wù),只需要讓nginx重新加載配置文件即可:
nginx -s reload
刷新瀏覽器,若反向代理成功,訪問的路徑會(huì)自動(dòng)映射到配置文件中的服務(wù)器地址!
將來,隨著用戶量的增長,可能需要添加新的服務(wù)器;這時(shí)只需要修改配置文件,使用 nginx -s reload 命令即可,無需關(guān)閉nginx服務(wù)器!
2. 關(guān)閉服務(wù)
關(guān)閉nginx服務(wù)的方式一般分為兩種:
nginx -s stop # 立即停止,無論是否在工作 nginx -s quit # 等待進(jìn)程完成當(dāng)前工作后安全退出
五、負(fù)載均衡
1. 什么是負(fù)載均衡?
由于不同服務(wù)器的配置不同,為了讓性能高的服務(wù)器分配到更多的請(qǐng)求,便引入了負(fù)載均衡的概念。
前面提到過,Nginx的負(fù)載均衡方式可以有很多種,如加權(quán)輪詢(默認(rèn))、IP哈希、url哈希等等,這里就以加權(quán)輪詢作為介紹。
加權(quán)輪詢,也就是通過給服務(wù)器添加各自的權(quán)重值,Nginx通過權(quán)重來進(jìn)行請(qǐng)求的分配,權(quán)重越高接收到的請(qǐng)求數(shù)量越多,反之越少:
上圖配置了三臺(tái)服務(wù)器,在加權(quán)輪詢的模式下,6次不同的請(qǐng)求中,權(quán)重為3的服務(wù)器將會(huì)分配到3次請(qǐng)求,權(quán)重為2的服務(wù)器會(huì)分配到2個(gè)請(qǐng)求,權(quán)重為1的服務(wù)器則會(huì)分配到1個(gè)請(qǐng)求。負(fù)載均衡大大減少了在高并發(fā)的環(huán)境下服務(wù)器宕機(jī)的風(fēng)險(xiǎn)!
2. 配置Nginx負(fù)載均衡
同樣地,打開nginx.conf文件進(jìn)行配置:
vim nginx.conf
在upstream塊中添加weight參數(shù):
upstream hello{ server 服務(wù)器1:8080 weight=3; # 配置服務(wù)器1的權(quán)重為3 server 服務(wù)器2:8080 weight=1; # 配置服務(wù)器2的權(quán)重為1 }
添加完成后執(zhí)行 nginx -s reload 即可!
以上就是Nginx服務(wù)快速入門教程的詳細(xì)內(nèi)容,更多關(guān)于nginx入門教程的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Nginx跨域設(shè)置Access-Control-Allow-Origin無效的解決辦法
今天小編就為大家分享一篇關(guān)于Nginx跨域設(shè)置Access-Control-Allow-Origin無效的解決辦法,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧2019-02-02FastDFS+Nginx如何搭建本地服務(wù)器并實(shí)現(xiàn)遠(yuǎn)程訪問
FastDFS是一個(gè)開源的輕量級(jí)分布式文件系統(tǒng),它對(duì)文件進(jìn)行管理,功能包括:文件存儲(chǔ)、文件同步、文件訪問(文件上傳、文件下載)等,解決了大容量存儲(chǔ)和負(fù)載均衡的問題,這篇文章主要介紹了FastDFS+Nginx搭建本地服務(wù)器并實(shí)現(xiàn)遠(yuǎn)程訪問,需要的朋友可以參考下2023-11-11nginx簡(jiǎn)單配置多個(gè)server的方法
這篇文章主要介紹了nginx簡(jiǎn)單配置多個(gè)server的方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11centos 7.0 使用Nginx部署flask應(yīng)用教程
這篇文章主要介紹了centos 7.0 使用Nginx部署flask應(yīng)用教程,需要的朋友可以參考下2017-12-12在網(wǎng)關(guān)中使用Nginx配置HTTP透明代理案例
這篇文章主要介紹了在網(wǎng)關(guān)中使用Nginx配置HTTP透明代理案例,中間還需要iptables配合,需要的朋友可以參考下2014-06-06