通過(guò)Lua擴(kuò)展Nginx

1. Nginx的簡(jiǎn)介

相關(guān)內(nèi)容柴墩,可以查看 【Nginx 負(fù)載均衡】鹃彻,這是我之前的一篇文章,這里就懶得再說(shuō)明一次了。


2. ngx_lua模塊

Nginx模塊需要用C開(kāi)發(fā)吸申,而且必須符合一系列復(fù)雜的規(guī)則锦聊,最重要的用C開(kāi)發(fā)模塊必須要熟悉Nginx的源代碼歹嘹,使得開(kāi)發(fā)者對(duì)其望而生畏。

ngx_lua模塊通過(guò)將lua解釋器集成進(jìn)Nginx孔庭,可以采用lua腳本實(shí)現(xiàn)業(yè)務(wù)邏輯尺上。
該模塊具備以下特性:

  1. 高并發(fā)材蛛、非阻塞的處理各種請(qǐng)求。
  2. Lua內(nèi)建協(xié)程怎抛,這樣就可以很好的將異步回調(diào)轉(zhuǎn)換成順序調(diào)用的形式卑吭。
  3. 每個(gè)協(xié)程都有一個(gè)獨(dú)立的全局環(huán)境(變量空間),繼承于全局共享的马绝、只讀的“commandata”豆赏。

得益于Lua協(xié)程的支持,ngx_lua在處理10000個(gè)并發(fā)請(qǐng)求時(shí)只需要很少的內(nèi)存富稻。根據(jù)測(cè)試掷邦,ngx_lua處理每個(gè)請(qǐng)求只需要2KB的內(nèi)存,如果使用LuaJIT則會(huì)更少椭赋。

ngx_lua非常適合用于實(shí)現(xiàn)可擴(kuò)展的耙饰、高并發(fā)的服務(wù)


3. 協(xié)程(Coroutine)

協(xié)程類似一種多線程,與多線程的區(qū)別有:

  1. 協(xié)程并非os線程纹份,所以創(chuàng)建苟跪、切換開(kāi)銷比線程相對(duì)要小。
  2. 協(xié)程與線程一樣有自己的棧蔓涧、局部變量等件已,但是協(xié)程的棧是在用戶進(jìn)程空間模擬的,所以創(chuàng)建元暴、切換開(kāi)銷很小篷扩。
  3. 多線程程序是多個(gè)線程并發(fā)執(zhí)行,也就是說(shuō)在一瞬間有多個(gè)控制流在執(zhí)行茉盏。而協(xié)程強(qiáng)調(diào)的是一種多個(gè)協(xié)程間協(xié)作的關(guān)系鉴未,只有當(dāng)一個(gè)協(xié)程主動(dòng)放棄執(zhí)行權(quán),另一個(gè)協(xié)程才能獲得執(zhí)行權(quán)鸠姨,所以在某一瞬間铜秆,多個(gè)協(xié)程間只有一個(gè)在運(yùn)行。
  4. 由于多個(gè)協(xié)程時(shí)只有一個(gè)在運(yùn)行讶迁,所以對(duì)于臨界區(qū)的訪問(wèn)不需要加鎖连茧,而多線程的情況則必須加鎖。
  5. 多線程程序由于有多個(gè)控制流巍糯,所以程序的行為不可控啸驯,而多個(gè)協(xié)程的執(zhí)行是由開(kāi)發(fā)者定義的所以是可控的。

Nginx的每個(gè)Worker進(jìn)程都是在epoll或kqueue這樣的事件模型之上祟峦,封裝成協(xié)程罚斗,每個(gè)請(qǐng)求都有一個(gè)協(xié)程進(jìn)行處理。這正好與Lua內(nèi)建協(xié)程的模型是一致的宅楞,所以即使ngx_lua需要執(zhí)行Lua针姿,相對(duì)C有一定的開(kāi)銷袱吆,但依然能保證高并發(fā)能力。


4. Nginx進(jìn)程模型

Nginx采用多進(jìn)程模型搓幌,單Master—多Worker,Master進(jìn)程主要用來(lái)管理Worker進(jìn)程迅箩。
Worker進(jìn)程采用單線程溉愁、非阻塞的事件模型(Event Loop,事件循環(huán))來(lái)實(shí)現(xiàn)端口的監(jiān)聽(tīng)及客戶端請(qǐng)求的處理和響應(yīng)饲趋,同時(shí)Worker還要處理來(lái)自Master的信號(hào)拐揭。Woker進(jìn)程個(gè)數(shù)一般設(shè)置為機(jī)器CPU核數(shù)。

Master進(jìn)程具體包括如下4個(gè)主要功能:
(1) 接收來(lái)自外界的信號(hào)奕塑。
(2) 向各worker進(jìn)程發(fā)送信號(hào)堂污。
(3) 監(jiān)控woker進(jìn)程的運(yùn)行狀態(tài)。
(4) 當(dāng)woker進(jìn)程退出后((異常情況下)龄砰,會(huì)自動(dòng)重新啟動(dòng)新的woker進(jìn)程盟猖。


5. HTTP請(qǐng)求處理



6. ngx_lua指令

ngx_lua屬于nginx的一部分,它的執(zhí)行指令都包含在nginx的11個(gè)步驟之中了换棚,相應(yīng)的處理階段可以做插入式處理式镐,即可插拔式架構(gòu),不過(guò)ngx_lua并不是所有階段都會(huì)運(yùn)行的;另外指令可以在http固蚤、server娘汞、server if、location夕玩、location if幾個(gè)范圍進(jìn)行配置:


7. OpenResty

  • 點(diǎn)擊查看官網(wǎng)

  • 概念:
    OpenResty是一個(gè)基于Nginx與Lua的高性能Web平臺(tái)你弦,其內(nèi)部集成了大量精良的Lua庫(kù)、第三方模塊以及大多數(shù)的依賴項(xiàng)燎孟。用于方便地搭建能夠處理超高并發(fā)禽作、擴(kuò)展性極高的動(dòng)態(tài)Web應(yīng)用、Web服務(wù)和動(dòng)態(tài)網(wǎng)關(guān)揩页。

  • 工作原理:
    OpenResty通過(guò)匯聚各種設(shè)計(jì)精良的Nginx模塊(主要由OpenResty團(tuán)隊(duì)自主開(kāi)發(fā))领迈,從而將Nginx有效地變成一個(gè)強(qiáng)大的通用Web應(yīng)用平臺(tái)。這樣碍沐,Web開(kāi)發(fā)人員和系統(tǒng)工程師可以使用Lua腳本語(yǔ)言調(diào)動(dòng)Nginx支持的各種C以及Lua模塊狸捅,快速構(gòu)造出足以勝任10K乃至1000K以上單機(jī)并發(fā)連接的高性能Web應(yīng)用系統(tǒng)。

  • 目標(biāo):
    OpenResty的目標(biāo)是讓你的Web服務(wù)直接跑在Nginx服務(wù)內(nèi)部累提,充分利用Nginx的非阻塞I/O模型尘喝,不僅僅對(duì)HTTP客戶端請(qǐng)求,甚至于對(duì)遠(yuǎn)程后端諸如MySQL、PostgreSQL斋陪、Memcached 以及Redis等都進(jìn)行一致的高性能響應(yīng)朽褪。


8. ngx_lua 實(shí)例

content_by_lua:內(nèi)容處理器置吓,接收請(qǐng)求處理并輸出響應(yīng)。

該指令工作在Nginx處理流程的content階段缔赠,即內(nèi)容產(chǎn)生階段,是所有請(qǐng)求處理階段中最為重要的階段衍锚,因?yàn)檫@個(gè)階段的指令通常是用來(lái)生成HTTP響應(yīng)內(nèi)容的;

輸出:

$ curl http://127.0.0.1/
$ Hello, world
  • 例子2
例子2
  • 例子3 - 傳參
例子3
  • 例子4 - 結(jié)合redis
例子4 - 1
例子4 - 2

如果覺(jué)得有收獲就點(diǎn)個(gè)贊吧,更多知識(shí)嗤堰,請(qǐng)點(diǎn)擊關(guān)注查看我的主頁(yè)信息哦~

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末戴质,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子踢匣,更是在濱河造成了極大的恐慌告匠,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,941評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件离唬,死亡現(xiàn)場(chǎng)離奇詭異后专,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)输莺,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,397評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門戚哎,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人嫂用,你說(shuō)我怎么就攤上這事建瘫。” “怎么了尸折?”我有些...
    開(kāi)封第一講書人閱讀 165,345評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵啰脚,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我实夹,道長(zhǎng)橄浓,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書人閱讀 58,851評(píng)論 1 295
  • 正文 為了忘掉前任亮航,我火速辦了婚禮荸实,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘缴淋。我一直安慰自己准给,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,868評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布重抖。 她就那樣靜靜地躺著露氮,像睡著了一般。 火紅的嫁衣襯著肌膚如雪钟沛。 梳的紋絲不亂的頭發(fā)上畔规,一...
    開(kāi)封第一講書人閱讀 51,688評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音恨统,去河邊找鬼叁扫。 笑死三妈,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的莫绣。 我是一名探鬼主播畴蒲,決...
    沈念sama閱讀 40,414評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼对室!你這毒婦竟也來(lái)了模燥?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書人閱讀 39,319評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤软驰,失蹤者是張志新(化名)和其女友劉穎涧窒,沒(méi)想到半個(gè)月后心肪,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體锭亏,經(jīng)...
    沈念sama閱讀 45,775評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,945評(píng)論 3 336
  • 正文 我和宋清朗相戀三年硬鞍,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了慧瘤。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,096評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡固该,死狀恐怖锅减,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情伐坏,我是刑警寧澤怔匣,帶...
    沈念sama閱讀 35,789評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站桦沉,受9級(jí)特大地震影響每瞒,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜纯露,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,437評(píng)論 3 331
  • 文/蒙蒙 一剿骨、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧埠褪,春花似錦浓利、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 31,993評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至渴语,卻和暖如春羽资,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背遵班。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 33,107評(píng)論 1 271
  • 我被黑心中介騙來(lái)泰國(guó)打工屠升, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留潮改,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,308評(píng)論 3 372
  • 正文 我出身青樓腹暖,卻偏偏與公主長(zhǎng)得像汇在,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子脏答,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,037評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容