Nginx的基本概念和原理是什么

一、nginx基本概念

(engine x)是一個高性能的http和反向代理web服務(wù)器,同時也提供了imap/pop3/smtp服務(wù)。其特點(diǎn)是占有內(nèi)存少,并發(fā)能力強(qiáng),事實(shí)上nginx的并發(fā)能力在同類型的網(wǎng)頁服務(wù)器中表現(xiàn)較好,中國大陸使用nginx網(wǎng)站用戶有:百度、京東、新浪、網(wǎng)易、騰訊、淘寶等。

Nginx專為性能優(yōu)化而開發(fā),性能是器最重要的考量,實(shí)現(xiàn)上非常注重效率,能經(jīng)受高負(fù)載的考驗(yàn),據(jù)報告能支持高達(dá)50,000個并發(fā)連接數(shù)。

Nginx不僅能做反向代理,實(shí)現(xiàn)負(fù)載均衡;還能可以作正向代理來進(jìn)行上網(wǎng)等功能。

二、反向代理

通過設(shè)置代理服務(wù)器,客戶端(瀏覽器)可以使用代理服務(wù)器去訪問互聯(lián)網(wǎng)。代理對象是客戶端,不知道服務(wù)端是誰。

Nginx的基本概念和原理是什么

客戶端不需要任何配置就能訪問,只需要將請求發(fā)送到反向代理服務(wù)器,由反向代理服務(wù)器去選擇目標(biāo)服務(wù)器,獲取數(shù)據(jù)后再返回給客戶端。外界只能訪問反向代理服務(wù)器地址,而真實(shí)服務(wù)器的IP地址則被隱藏。代理對象是服務(wù)端,不知道客戶端是誰。

Nginx的基本概念和原理是什么

三、負(fù)載均衡

服務(wù)器會處理客戶端發(fā)送的多個請求,有些請求可能需要訪問數(shù)據(jù)庫,最終服務(wù)器會在處理完畢后將結(jié)果返回給客戶端。

這種架構(gòu)模式單一,適合并發(fā)請求少的情況,但并發(fā)量大的時候如何解決?

Nginx的基本概念和原理是什么

首先可能想到升級服務(wù)器配置,但硬件的性能提升不能滿足日益增長的需求,此時想到服務(wù)器集群,增加服務(wù)器數(shù)量,然后將原先請求單個服務(wù)器的情況改為將請求分發(fā)到多個服務(wù)器上,將負(fù)載分發(fā)到多個服務(wù)器上,也就是我們講的

Nginx的基本概念和原理是什么

四、動靜分離

為了加速網(wǎng)站解析速度,可以使用不同的服務(wù)器來分別解析動態(tài)頁面和靜態(tài)頁面,從而減少服務(wù)器的負(fù)擔(dān),加快解析速度。

Nginx的基本概念和原理是什么

五、原理

mater&worker

Nginx的基本概念和原理是什么

master接收信號后將任務(wù)分配給worker進(jìn)行執(zhí)行,worker可有多個。

Nginx的基本概念和原理是什么

六、worker如何工作

客戶端發(fā)送一個請求到master后,worker獲取任務(wù)的機(jī)制不是直接分配也不是輪詢,而是一種爭搶的機(jī)制,“搶”到任務(wù)后再執(zhí)行任務(wù),即選擇目標(biāo)服務(wù)器tomcat等,然后返回結(jié)果。

Nginx的基本概念和原理是什么

worker_connection

發(fā)送請求占用了woker兩個或四個連接數(shù)。

  • 普通的靜態(tài)訪問最大并發(fā)數(shù)是:worker_connections *worker_processes/ 2 /2/2

  • 若是 HTTP 作 為反向代理來說,最大并發(fā)數(shù)量應(yīng)該是 worker_connections *worker_processes/ 4 /4/4。

當(dāng)然了,worker數(shù)也不是越多越好,worker數(shù)和服務(wù)器的CPU數(shù)相等時最適宜的。

優(yōu)點(diǎn):

  • 可以使用 nginx –s reload 熱部署,利用 nginx 進(jìn)行熱部署操作

  • 每個 woker 是獨(dú)立的進(jìn)程,若其中一個woker出現(xiàn)問題,其他繼續(xù)進(jìn)行爭搶,實(shí)現(xiàn)請求過程,不會造成服務(wù)中斷

? 版權(quán)聲明
THE END
喜歡就支持一下吧
點(diǎn)贊14 分享