色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

通過對網關設計的介紹來簡單總結一下OpenResty的相關知識點

Linux愛好者 ? 來源:碼海 ? 2020-08-14 16:36 ? 次閱讀

前言

希望通過對網關設計的介紹來簡單總結一下 OpenResty 的相關知識點,爭取讓大家對 OpenResty 這種高性能 Web 平臺有一個比較全面的了解。本文會從以下幾個方面來講解。

網關的作用

接入層網關架構設計與實現

技術選型

OpenResty 原理剖析

網關的作用

網關作為所有請求的流量入口,主要承擔著安全,限流,熔斷降級,監控,日志,風控,鑒權等功能,網關主要有兩種類型

一種是接入層網關(access gateway),主要負責路由,WAF(防止SQL Injection, XSS, 路徑遍歷, 竊取敏感數據,CC攻擊等),限流,日志,緩存等,這一層的網關主要承載著將請求路由到各個應用層網關的功能

另一種是應用層網關,比如現在流行的微服務,各個服務可能是用不同的語言寫的,如 PHP,Java 等,那么接入層就要將請求路由到相應的應用層集群,再由相應的應用層網關進行鑒權等處理,處理完之后再調用相應的微服務進行處理,應用層網關也起著路由,超時,重試,熔斷等功能。

目前市面上比較流行的系統架構如下

可以看到接入層網關承載著公司的所有流量,對性能有很高的要求,它的設計決定著整個系統的上限。所以我們今天主要談談接入層網關的設計。

接入層網關架構設計與實現

首先我們要明白接入層網關的核心功能是:「根據路由規則將請求分發到對應的后端集群」,所以要實現如下幾個功能模型 。

1、 路由:根據請求的 host, url 等規則轉發到指定的上游(相應的后端集群) 2、 路由策略插件化:這是網關的「靈魂所在」,路由中會有身份認證,限流限速,安全防護(如 IP 黑名單,refer異常,UA異常,需第一時間拒絕)等規則,這些規則以插件的形式互相組合起來以便只對某一類的請求生效,每個插件都即插即用,互不影響,這些插件應該是「動態可配置」的,動態生效的(無須重啟服務),為啥要可動態可配置呢,因為每個請求對應的路由邏輯,限流規則,最終請求的后端集群等規則是不一樣的

如圖示,兩個請求對應的路由規則是不一樣的,它們對應的路由規則(限流,rewrite)等通過各個規則插件組合在一起,可以看到,光兩個請求 url 的路由規則就有挺多的,如果一個系統大到一定程度,url 會有不少,就會有不少規則,這樣每個請求的規則就必須「可配置化」,「動態化」,最好能在管理端集中控制,統一下發。

3、后端集群的動態變更

路由規則的應用是為了確定某一類請求經過這些規則后最終到達哪一個集群,而我們知道請求肯定是要打到某一臺集群的 ip 上的,而機器的擴縮容其實是比較常見的,所以必須支持動態變更,總不能我每次上下線機器的時候都要重啟系統讓它生效吧。

4、監控統計,請求量、錯誤率統計等等

這個比較好理解,在接入層作所有流量的請求,錯誤統計,便于打點,告警,分析。

要實現這些需求就必須對我們采用的技術:OpenResty 有比較詳細的了解,所以下文會簡單介紹一下 OpenResty 的知識點。

技術選型

有人可能第一眼想到用 Nginx,沒錯,由于 Nginx 采用了 epoll 模型(非阻塞 IO 模型),確實能滿足大多數場景的需求(經過優化 100 w + 的并發數不是問題),但是 Nginx 更適合作為靜態的 Web 服務器,因為對于 Nginx 來說,如果發生任何變化,都需要修改磁盤上的配置,然后重新加載才能生效,它并沒有提供 API 來控制運行時的行為,而如上文所述,動態化是接入層網關非常重要的一個功能。所以經過一番調研,我們選擇了 OpenResty,啥是 OpenResty 呢,來看下官網的定義:

?

OpenResty 是一個基于 Nginx 與 Lua 的高性能 Web 平臺,其內部集成了大量精良的 Lua 庫、第三方模塊以及大多數的依賴項。用于方便地搭建能夠處理超高并發、擴展性極高的動態 Web 應用、Web 服務和動態網關。OpenResty 的目標是讓你的Web服務直接跑在 Nginx 服務內部,充分利用 Nginx 的非阻塞 I/O 模型,不僅僅對 HTTP 客戶端請求,甚至于對遠程后端諸如 MySQL、PostgreSQL、Memcached 以及 Redis 等都進行一致的高性能響應。

?

可以簡單理解為,OpenResty = Nginx + Lua, 通過 Lua 擴展 Nginx 實現的可伸縮的 Web 平臺 。它利用了 Nginx 的高性能,又在其基礎上添加了 Lua 的腳本語言來讓 Nginx 也具有了動態的特性。通過 OpenResty 中 lua-Nginx-module 模塊中提供的 Lua API,我們可以動態地控制路由、上游、SSL 證書、請求、響應等。甚至可以在不重啟 OpenResty 的前提下,修改業務的處理邏輯,并不局限于 OpenResty 提供的 Lua API。

關于靜態和動態有一個很合適的類比:如果把 Web 服務器當做是一個正在高速公路上飛馳的汽車,Nginx 需要停車才能更換輪胎,更換車漆顏色,而 OpenResty 中可以邊跑邊換輪胎,更換車漆,甚至更換發動機,直接讓普通的汽車變成超跑!

除了以上的動態性,還有兩個特性讓 OpenResty 獨出一格。

「1.詳盡的文檔和測試用例」

作為開源項目,文檔和測試毫無疑問是其是否靠譜的關鍵,它的文檔非常詳細,作者把每個注意的點都寫在文檔上了,多數時候只要看文檔即可,每一個測試案例都包含完整的 Nginx 配置和 lua 代碼。以及測試的輸入數據和預期的輸出數據。

「2.同步非阻塞」

OpenResty 在誕生之初就支持了協程,并且基于此實現了同步非阻塞的編程模型。

「畫外音:協程(coroutine)我們可以將它看成一個用戶態的線程,只不過這個線程是我們自己調度的,而且不同協程的切換不需要陷入內核態,效率比較高。(一般我們說的線程是要指內核態線程,由內核調度,需要從用戶空間陷入內核空間,相比協程,對性能會有不小的影響)」

啥是同步非阻塞呢。假設有以下兩個兩行代碼:

localres,err=query-mysql(sql) localvalue,err=query-redis(key)

「同步」:必須執行完查詢 mysql,才能執行下面的 redis 查詢,如果不等 mysql 執行完成就能執行 redis 則是異步。

「阻塞」:假設執行 sql 語句需要 1s,如果在這 1s 內,CPU 只能干等著不能做其它任何事,那就是阻塞,如果在 sql 執行期間可以做其他事(注意由于是同步的,所以不能執行以下的 redis 查詢),則是非阻塞。

同步關注的是語句的先后執行順序,如果上一個語句必須執行完才能執行下一個語句就是同步,如果不是,就是異步,阻塞關注的是線程是 CPU 是否需要在 IO 期間干等著,如果在 IO(或其他耗時操作期間)期間可以做其他事,那就是非阻塞,不能動,則是阻塞。

那么 OpenResty 的工作原理是怎樣的呢,又是如何實現同步非阻塞的呢。

OpenResty 原理剖析

工作原理剖析

由于 OpenResty 基于 Nginx 實現的,我們先來看看 Nginx 的工作原理

Nginx 啟動后,會有一個 master 進程和多個 worker 進程 , master 進程接受管理員的信號量(如 Nginx -s reload, -s stop)來管理 worker 進程,master 本身并不接收 client 的請求,主要由 worker 進程來接收請求,不同于 apache 的每個請求會占用一個線程,且是同步IO,Nginx 是異步非阻塞的,每個 worker 可以同時處理的請求數只受限于內存大小,這里就要簡單地了解一下 nginx 采用的 epoll 模型:

epoll 采用多路復用模型,即同一時間雖然可能會有多個請求進來, 但只會用一個線程去監視,然后哪個請求數據準備好了,就調用相應的線程去處理,就像圖中所示,如同撥開關一樣,同一時間只有一個線程在處理, Nginx 底層就是用的 epoll ,基于事件驅動模型,每個請求進來注冊事件并注冊 callback 回調函數,等數據準入好了,就調用回調函數進行處理,它是異步非阻塞的,所以性能很高。

打個簡單的比方,我們都有訂票的經驗,當我們委托酒店訂票時,接待員會先把我們的電話號碼和相關信息等記下來(注冊事件),掛斷電話后接待員在操作期間我們就可以去做其他事了(非阻塞),當接待員把手續搞好后會主動打電話給我們通知我們票訂好了(回調)。

worker 進程是從 master fork 出來的,這意味著 worker 進程之間是互相獨立的,這樣不同 worker 進程之間處理并發請求幾乎沒有同步鎖的限制,好處就是一個 worker 進程掛了,不會影響其他進程,我們一般把 worker 數量設置成和 CPU 的個數,這樣可以減少不必要的 CPU 切換,提升性能,每個 worker 都是單線程執行的。那么 LuaJIT 在 OpenResty 架構中的位置是怎樣的呢。

首先啟動的 master 進程帶有 LuaJIT 的機虛擬,而 worker 進程是從 master 進程 fork 出來的,在 worker 內進程的工作主要由 Lua 協程來完成,也就是說在同一個 worker 內的所有協程,都會共享這個 LuaJIT 虛擬機,每個 worker 進程里 lua 的執行也是在這個虛擬機中完成的。

同一個時間點,worker 進程只能處理一個用戶請求,也就是說只有一個 lua 協程在運行,那為啥 OpenResty 能支持百萬并發請求呢,這就需要了解 Lua 協程與 Nginx 事件機制是如何配合的了。

如圖示,當用 Lua 調用查詢 MySQL 或 網絡 IO 時,虛擬機會調用 Lua 協程的 yield 把自己掛起,在 Nginx 中注冊回調,此時 worker 就可以處理另外的請求了(非阻塞),等到 IO 事件處理完了, Nginx 就會調用 resume 來喚醒 lua 協程。

事實上,由 OpenResty 提供的所有 API,都是非阻塞的,下文提到的與 MySQL,Redis 等交互,都是非阻塞的,所以性能很高。

OpenResty 請求生命周期

Nginx 的每個請求有 11 個階段,OpenResty 也有11 個 *_by_lua 的指令,如下圖示:

各個階段 *_by_lua 的解釋如下

set_by_lua:設置變量; rewrite_by_lua:轉發、重定向等; access_by_lua:準入、權限等; content_by_lua:生成返回內容; header_filter_by_lua:應答頭過濾處理; body_filter_by_lua:應答體過濾處理; log_by_lua:日志記錄。

這樣分階段有啥好處呢,假設你原來的 API 請求都是明文的

# 明文協議版本 location /request { content_by_lua '...'; # 處理請求 }

現在需要對其加上加密和解密的機制,只需要在 access 階段解密, 在 body filter 階段加密即可,原來 content 的邏輯無需做任務改動,有效實現了代碼的解藕。

# 加密協議版本 location /request { access_by_lua '...'; # 請求體解密 content_by_lua '...'; # 處理請求,不需要關心通信協議 body_filter_by_lua '...'; # 應答體加密 }

再比如我們不是要要上文提到網關的核心功能之一不是要監控日志嗎,就可以統一在 log_by_lua 上報日志,不影響其他階段的邏輯。

worker 間共享數據利器: shared dict

worker 既然是互相獨立的進程,就需要考慮其共享數據的問題, OpenResty 提供了一種高效的數據結構: shared dict ,可以實現在 worker 間共享數據,shared dict 對外提供了 20 多個 Lua API,都是原子操作的,避免了高并發下的競爭問題。

路由策略插件化實現

有了以上 OpenResty 點的鋪墊,來看看上文提的網關核心功能 「路由策略插件化」,「后端集群的動態變更」如何實現

首先針對某個請求的路由策略大概是這樣的

整個插件化的步驟大致如下

1、每條策略由 url ,action, cluster 等組成,代表請求 url 在打到后端集群過程中最終經歷了哪些路由規則,這些規則統一在我們的路由管理平臺配置,存在 db 里。

2、OpenResty 啟動時,在請求的 init 階段 worker 進程會去拉取這些規則,將這些規則編譯成一個個可執行的 lua 函數,這一個個函數就對應了一條條的規則。

需要注意的是為了避免重復去 MySQL 中拉取數據,某個 worker 從 MySQL 拉取完規則(此步需要加鎖,避免所有 worker 都去拉?。┗蛘吆蠖思旱扰渲眯畔⒑笠獙⑵浔4嬖?shared dict 中,這樣之后所有的 worker 請求只要從 shared dict 中獲取這些規則,然后將其映射成對應模塊的函數即可,如果配置規則有變動呢,配置后臺通過接口通知 OpenResty 重新加載一下即可

經過路由規則確定好每個請求對應要打的后端集群后,就需要根據 upstream 來確定最終打到哪個集群的哪臺機器上,我們看看如何動態管理集群。

后端集群的動態配置

在 Nginx 中配置 upstream 的格式如下

upstreambackend{ serverbackend1.example.comweight=5; serverbackend2.example.com; server192.0.0.1backup; }

以上這個示例是按照權重(weight)來劃分的,6 個請求進來,5個請求打到 backend1.example.com, 1 個請求打到 backend2.example.com,如果這兩臺機器都不可用,就打到 192.0.0.1,這種靜態配置的方式 upstream 的方式確實可行,但我們知道機器的擴縮容有時候比較頻繁,如果每次機器上下線都要手動去改,并且改完之后還要重新去 reload 無疑是不可行的,出錯的概率很大,而且每次配置都要 reload 對性能的損耗也是挺大的,為了解決這個問題,OpenResty 提供了一個 dyups 的模塊來解決此問題, 它提供了一個 dyups api,可以動態增,刪,創建 upsteam,所以在 init 階段我們會先去拉取集群信息,構建 upstream,之后如果集群信息有變動,會通過如下形式調用 dyups api 來更新 upstream

--動態配置upstream接口站點 server{ listen127.0.0.1:81; location/{ dyups_interface; } } --增加upstream:user_backend curl-d"server10.53.10.191;"127.0.0.1:81/upstream/user_backend --刪除upstream:user_backend curl-i-XDELETE127.0.0.1:81/upstream/user_backend

使用 dyups 就解決了動態配置 upstream 的問題

網關最終架構設計圖

通過這樣的設計,最終實現了網關的配置化,動態化。

總結

網關作為承載公司所有流量的入口,對性能有著極高的要求,所以技術選型上還是要慎重,之所以選擇 OpenResty,一是因為它高性能,二是目前也有小米,阿里,騰訊等大公司在用,是久經過市場考驗的,本文通過對網關的總結簡要介紹了 OpenResty 的相關知識點,相信大家對其主要功能點應該有所了解了,不過 OpenResty 的知識點遠不止以上這些,大家如有興趣,可以參考文末的學習教程深入學習,相信大家會有不少啟發的。

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 網關
    +關注

    關注

    9

    文章

    4579

    瀏覽量

    51374
  • 路由
    +關注

    關注

    0

    文章

    278

    瀏覽量

    41891
  • 應用層
    +關注

    關注

    0

    文章

    46

    瀏覽量

    11526

原文標題:高性能網關設計實踐

文章出處:【微信號:LinuxHub,微信公眾號:Linux愛好者】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    Aigtek功率放大器應用:電感線圈的知識點分享

    電磁驅動是功率放大器的大基礎應用領域,其中我們最常見的就是用功放來驅動電感線圈,那么關于電感線圈的這10大知識點你都知道嗎?今天Aigtek安泰電子來給大家介紹一下電感線圈的基礎
    的頭像 發表于 01-07 15:43 ?134次閱讀
    Aigtek功率放大器應用:電感線圈的<b class='flag-5'>知識點</b>分享

    后悔沒有早點看到:天線設計中的知識點!

    Cat.1 bis R13架構,天線架構精簡為單天線架構,去掉了分集接收天線,因此只需要根天線。 ? 知識點: Cat.1 bis相對于Cat.1的區別是,后者為兩根天線(根主天線,
    的頭像 發表于 12-24 17:11 ?456次閱讀
    后悔沒有早點看到:天線設計中的<b class='flag-5'>知識點</b>!

    推拉力測試知識點介紹

    、【推拉力測試介紹】 推拉力測試是種工程測試方法,用于評估材料、器件或系統在受到推力或拉力作用的性能和可靠性。這種測試廣泛應用于多個行業,包括航空航天、汽車、建筑和制造業等。
    的頭像 發表于 11-15 16:15 ?899次閱讀
    推拉力測試<b class='flag-5'>知識點</b><b class='flag-5'>介紹</b>

    接口測試理論、疑問收錄與擴展相關知識點

    本文章使用王者榮耀游戲接口、企業微信接口的展示結合理論知識,講解什么是接口測試、接口測試理論、疑問收錄與擴展相關知識點知識學院,快來起看
    的頭像 發表于 11-15 09:12 ?368次閱讀
    接口測試理論、疑問收錄與擴展<b class='flag-5'>相關</b><b class='flag-5'>知識點</b>

    MySQL知識點匯總

    大家好,這部分被稱為DQL部分,是每個學習MySQL必須要學會的部分,下面就讓我介紹MySQL中的其他部分。
    的頭像 發表于 08-05 15:27 ?428次閱讀
    MySQL<b class='flag-5'>知識點</b>匯總

    陷波濾波器的相關知識

    System)簡單討論一下陷波濾波器(Notch Filter)和梳狀濾波器(Comb Filter),通過代碼的演示和輸出,我們可以比較一下
    的頭像 發表于 06-13 10:16 ?1080次閱讀
    陷波濾波器的<b class='flag-5'>相關</b><b class='flag-5'>知識</b>

    模擬電子技術知識點問題總結概覽

    給大家分享模擬電子技術知識點問題總結。
    的頭像 發表于 05-08 15:16 ?1213次閱讀
    模擬電子技術<b class='flag-5'>知識點</b>問題<b class='flag-5'>總結</b>概覽

    HarmonyOS實戰開發-如何通過BlendMode屬性實現掛件和圖片的混合

    ; this.currentBlendMode = item.blendMode; 高性能知識點 數據通過LazyForEach進行遍歷。 工程結構&模塊類型 blendmode// har類型 |---model
    發表于 05-07 14:45

    總結一下LM317的幾種經典應用電路

    說起LM317,我們做硬件的都很熟悉了,它是LDO的種,并且輸出電壓很容易通過外部電阻進行調整,今天總結一下LM317的幾種經典應用電路。
    的頭像 發表于 05-01 10:07 ?6200次閱讀
    <b class='flag-5'>總結</b><b class='flag-5'>一下</b>LM317的幾種經典應用電路

    基于FPGA的常見的圖像算法模塊總結

    意在給大家補充一下基于FPGA的圖像算法基礎,于是講解了一下常見的圖像算法模塊,經過個人的總結,將知識點分布如下所示。
    的頭像 發表于 04-28 11:45 ?635次閱讀
    基于FPGA的常見的圖像算法模塊<b class='flag-5'>總結</b>

    篇搞定DCS系統相關知識點

    目標。DCS系統廣泛應用于各個行業,如化工、電力、制藥等。在這些行業中,DCS系統可以實現對生產過程的集中監控和分散控制,提高生產效率和產品質量,降低能耗和減少環境污染,從而保證產品質量,并確保生產過程的安全可靠。 二.DCS系統知識點
    的頭像 發表于 03-26 18:40 ?976次閱讀
    <b class='flag-5'>一</b>篇搞定DCS系統<b class='flag-5'>相關</b><b class='flag-5'>知識點</b>

    【量子計算機重構未來 | 閱讀體驗】第二章關鍵知識點

    本帖最后由 oxlm_1 于 2024-3-6 23:20 編輯 之所以將第二章單獨拿出來,是因為在閱讀過程中,發現第二章知識點較多,理解起來比較耗時間。 第二章的主要知識點: 量子
    發表于 03-06 23:17

    雕刻主軸相關知識總結分享!|深圳恒興隆機電a

    工作原理、結構特點、選購要點等方面介紹雕刻主軸的相關知識。接下來就跟著深圳恒興隆機電小編起來看下吧!、雕刻主軸的工作原理雕刻主軸主要由電
    發表于 02-26 10:30

    簡單介紹一下電源紋波與電容嘯叫

    簡單介紹一下電源紋波與電容嘯叫? 電源紋波與電容嘯叫是在電源系統中常見的兩種問題,它們會影響電子設備的性能和穩定性。本篇文章將詳細介紹電源紋波和電容嘯叫的定義、原因、對設備的影響以及常
    的頭像 發表于 02-04 09:42 ?1111次閱讀

    鴻蒙知識點

    install package File ? 這里列舉的幾個命令是不是很熟悉?看名字就知道和安卓中的adb是對應關系。不需要去記憶,在需要使用到的時候去官網查一下就行: hdc使用指導 2、Mac系統配置hdc 環境變量 3、項目中的
    的頭像 發表于 01-31 17:40 ?1004次閱讀
    鴻蒙<b class='flag-5'>知識點</b>
    主站蜘蛛池模板: 久久久久免费视频| 国产99热在线观看| 日日天干夜夜狠狠爱| 久久精品视频在线看99| 国产精品亚洲精品日韩电影| 99爱在线精品视频网站| 亚洲国产欧美日本大妈| 日本久久久WWW成人免费毛片丨| 久久精品动漫网一区二区| 国产成人精品男人的天堂网站 | 4虎最新网址| 亚洲精品国产自在在线观看| 三级aa久久| 女人张腿让男人桶免费| 久久精品视在线观看2| 好嗨哟在线看片免费| 国产成人精品综合在线观看| 9久爱午夜视频| 最近中文字幕在线中文视频| 亚洲精品在线影院| 亚洲AV精品乱码专区| 四虎国产精品高清在线观看| 青青草原伊人网| 男人插曲女人的叫声| 快播最新电影网站| 久久久免费热线精品频| 换脸国产AV一区二区三区| 国产久爱青草视频在线观看| 攻把受做得合不拢腿play| 超碰久久国产vs| qvod播放电影| xxxx88| a在线观看视频| 99久久蜜臀AV免费看蛮| 87.6在线收听| 99国产在线精品视频| 999视频精品全部免费观看| 99精品国产第一福利网站| 91素人约啪| 99视频精品在线| xxxxxl荷兰|