Nginx 瞭解一下?

Nginx 瞭解一下?

這篇文章主要簡單的介紹下 Nginx 的相關知識,主要包括以下幾部分內容:

  1. Nginx 適用於哪些場景?
  2. 為什麼會出現 Nginx?
  3. Nginx 優點
  4. Nginx 的編譯與配置

Nginx 適用於哪些場景?

Nginx 瞭解一下?

如圖所示,一個請求會先經過 Nginx 到達應用服務層,然後再去訪問數據層(比如 Redis、MySQL 等),提供基本的數據功能。我們的應用服務因為要求開發效率是非常高的,所以它的運行效率是很低的,它的 qps、tps或者併發都是受限的,所以我們需要把很多這樣的應用服務組成集群,向用戶提供高可用服務。而一旦很多服務構成集群的時候,我們需要 Nginx 具備反向代理功能,可以把動態請求傳遞給應用服務。

而當應用服務構成集群,一定會帶來兩個需求:

  1. 需要動態的擴容
  2. 有些服務出現問題的時候我們需要做容災

這樣反向代理必須具備負載均衡功能。

其次在這樣的一個鏈路中, Nginx 是處在企業內網的一個邊緣節點,隨著網絡鏈路的增長,用戶體驗到的時延會增加,所以需要把用戶看起來不變的或者在一段時間內看起來不變的動態內容緩存在 Nginx 部分,由 Nginx 直接向用戶提供訪問,這樣用戶時延就會減少很多。所以反向代理延伸出另外一個功能就是緩存,來減少用戶訪問的時延。

像很多 css、js、img 靜態資源,是沒有必要通過應用服務來訪問的,只需要本地文件系統上放置的靜態資源,直接由 Nginx 提供訪問就可以了。這是 Nginx 的靜態資源服務。

應用服務本身的性能存在很多問題,像數據庫服務比應用服務好的多,因為業務場景比較簡單,併發性能和tps都要遠高於應用服務,所以延伸出第三個應用場景:由 Nginx 直接去訪問數據庫、Redis,利用 Nginx 強大的併發性能實現如 web防火牆 複雜的一些業務功能。這就需要api服務有很強的業務處理功能,所以像 OpenResty、 Nginx 集成的 JavaScript,應用 JavaScript、lua 這樣的語言功能和它們語言自帶的一些工具庫來提供完整的 API服務。

為什麼會出現 Nginx?

伴隨著互聯網的快速普及、以及全球化和物聯網的快速發展,導致互聯網的數據量快速增長。

CPU 核數從當初的單核發展到 16 核,甚至 32 核,但是由於操作系統和大量的軟件沒有做好服務於多核架構的準備,致使服務的性能通常不會有成倍的提升。

Apache 的架構模型一個進程同一時間只會處理一個鏈接一個請求,處理完以後才會處理下一個請求。它實際上在使用操作系統的進程間切換的特性,因為操作系統微觀上只有有限的 CPU,但是操作系統被設計為同時服務數百甚至上千的進程,而 Apache 一個進程只能服務於一個鏈接,這樣的模式會導致當 Apache 需要面對幾十萬、幾百萬鏈接的時候,它沒有辦法去開幾十萬、幾百萬的進程;而進程間切換的代價成本又太高了,當併發的連接數越多,這種無謂的進程間切換引發的性能消耗也就越大,而 Nginx 是專門為了這樣的應用場景而生的,Nginx 可以處理數百萬甚至上千萬的併發鏈接。

Nginx 優點

一、高併發,高性能

只要我們對每個鏈接使用的內存足夠少就能實現高併發;既要達到高併發又要達到高性能,往往需要很好的設計。

比如現在的主流雲服務器,nginx 在 32 核 64G 的配置中可以輕鬆達到數千萬的併發鏈接;如果是處理簡單的靜態資源請求,nginx 可以達到 100w 的 RPS 。

RPS(Requests Per Second)為每秒能處理的請求數目,等效於 QPS(Queries Per Second),也就是每秒能處理查詢數目。是一臺服務器每秒能夠相應的查詢次數,是對一個特定的查詢服務器在規定時間內所處理流量多少的衡量標準。

二、可擴展性好

可擴展性主要體現在模塊化設計;模塊化設計非常穩定,使得 Nginx 的生態圈、第三方模塊非常豐富。甚至於有 Tengine、OpenResty 這樣的第三方插件在他的基礎之上又生成了新的生態圈。豐富的生態圈和第三方模塊為 Nginx 的豐富功能提供了保證。

三、高可靠性

高可靠性指的是 Nginx 可以服務器上持續不間斷的運行數年,而很多web服務器往往運行幾周or幾個月,就需要進行一次重啟。對於 Nginx 這樣一個高併發、高性能的反向代理服務器而言,往往運行在企業內網的邊緣節點上,這個時候如果我們企業想提供4個9、5個9、甚至更高的高可用性時,對於 Nginx 持續運行能夠宕機的時間一年可能只能以秒來計,所以在這樣一個角色中,Nginx 的高可靠性給我們提供了非常好的保證。

四、熱部署

熱部署是指在不停止服務的情況下升級Nginx。這個功能對於 Nginx 來說非常重要,因為在服務器上跑了數百萬的併發鏈接,如果是普通的服務器,我們只能 kill 掉進程再重啟的方式進行升級操作。但是對於 Nginx 而言,因為直接 kill 掉 nginx 進程會給所有的已經建立鏈接的客戶端一個很不好的體驗。

五、BSD 許可證

BSD許可證是指 Nginx 不只是開源的、免費的,而且我們可以在有定製需求的場景下,去修改 Nginx 的源碼,再運行在我們的商業場景下且屬於合法的。

Nginx 組成

Nginx 主要由以下 4 部分組成:

  • Nginx 二進制可執行文件:由各模塊源碼編譯出的一個文件
  • Nginx.conf 配置文件:控制 Nginx 行為
  • access.log 訪問日誌:記錄每一條 http 請求信息
  • error.log 錯誤日誌:定位問題

接下來,我們就要動手去編譯 Nginx 了。

編譯 Nginx

Nginx 瞭解一下?

在 configure 過程中可能遇到的問題:

Nginx 瞭解一下?

出錯的原因是 Nginx 模塊需要依賴一些 lib 庫,解決辦法如下:

Nginx 瞭解一下?

Nginx 配置

Nginx 配置語法

Nginx 瞭解一下?

Nginx 配置參數

配置參數:時間的單位

Nginx 瞭解一下?

配置參數:空間的單位

Nginx 瞭解一下?

http 配置的指令塊

Nginx 瞭解一下?

  • http:表示裡面所有的指令都是由 http 模塊去解析去執行的
  • server:解析對應的域名or一組域名
  • location:url 表達式
  • upstream:表示上游服務,需要與企業內網服務直連的時候,可以定義一個 upstream

示例

Nginx 瞭解一下?

示例中的所有指令都是由 Nginx 中的 http 模塊去執行的,其中 server 127.0.0.1:8000 為需要解析的域名,location 後面跟的為對應的匹配規則,expires 3m表示 3 分鐘後 cache 刷新,zone=one:10m表示開闢了一個 10m 大小的共享內存空間,給不同的 worker 去使用。

總結

這篇文章主要介紹了 Nginx 出現的原因和使用場景,並分析 Nginx 的優點,最後動手去編譯屬於自己的 Nginx,並進行簡單配置。


分享到:


相關文章: