• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            那誰的技術博客

            感興趣領域:高性能服務器編程,存儲,算法,Linux內(nèi)核
            隨筆 - 210, 文章 - 0, 評論 - 1183, 引用 - 0
            數(shù)據(jù)加載中……

            Nginx0.7.61代碼分析(三)--事件處理

            Nginx里面的事件處理與其他服務器所做的事件處理模型其實大同小異---都是封裝了一個事件通知的結構體,然后會對每個平臺上常用的事件觸發(fā)器做封裝(epoll/select/poll/...),根據(jù)編譯時配置來決定選擇哪個事件處理器,當然,這個選擇也可以在配置文件中指定。

            封裝事件處理的結構體在ngx_event_s中定義,其中的handler是處理事件的函數(shù)指針。

            對于監(jiān)聽socket而言,這個handler函數(shù)指針指向的是函數(shù)ngx_event_accept函數(shù)。顯然,這個函數(shù)是用于接收新連接。
            當接收新的連接之后,對連接socket而言,這個函數(shù)指針指向ngx_http_init_request 函數(shù)。假如這個函數(shù)執(zhí)行成功,handler函數(shù)指針會改為指向ngx_http_process_request_line函數(shù)。其他的以此類推,我沒有繼續(xù)跟進這些與http具體業(yè)務相關的處理函數(shù)。

            所以,可以看到,在處理一個連接請求的每個階段,都對應的是不同的handler函數(shù),在每個handler函數(shù)中,會在執(zhí)行成功之后修改handler函數(shù)指針指向下一個階段的處理函數(shù)。

            與之前分析過的lighhtpd的狀態(tài)機相比,Nginx里面的handler函數(shù)之間,耦合關系更緊密一些,也就是說,在狀態(tài)處理的每個階段,都需要知道下一個階段是由哪個函數(shù)進行處理。我個人更喜歡lighttpd的狀態(tài)機,因為這個狀態(tài)機使得每個階段的狀態(tài)耦合的不那么緊密,每次狀態(tài)處理完畢,該狀態(tài)的處理函數(shù)只需要保存本次處理的結果,然后進入狀態(tài)機處理函數(shù)中,由它來選擇處理的走向。




            posted on 2009-12-09 23:47 那誰 閱讀(5387) 評論(0)  編輯 收藏 引用 所屬分類: 服務器設計Nginx

            久久美女网站免费| 久久国产精品99久久久久久老狼 | 久久久久成人精品无码中文字幕| 精品久久久久久成人AV| 99久久超碰中文字幕伊人| 国产精品亚洲综合专区片高清久久久| 久久久久免费视频| 无码伊人66久久大杳蕉网站谷歌| 精品免费tv久久久久久久| 色综合久久88色综合天天 | 国产亚洲色婷婷久久99精品| 人妻丰满?V无码久久不卡| 国产精品女同久久久久电影院| 久久婷婷色综合一区二区| 精品久久久久久无码专区不卡| 久久男人AV资源网站| 久久国产精品-久久精品| 久久国产欧美日韩精品| 久久久91人妻无码精品蜜桃HD| 国产综合久久久久久鬼色| 精品久久久一二三区| 91麻精品国产91久久久久 | 狠狠色综合网站久久久久久久高清| 久久九九亚洲精品| 久久精品国产亚洲av高清漫画| 国产精品久久久久久久久软件 | 精品一区二区久久久久久久网站| 麻豆久久久9性大片| 久久久久国产成人精品亚洲午夜| 久久夜色精品国产亚洲| 国产精品视频久久久| 99久久婷婷国产综合亚洲| 无码伊人66久久大杳蕉网站谷歌| 精品久久久久久久国产潘金莲| 久久青青草原精品国产软件| 国产精品欧美亚洲韩国日本久久 | 2021最新久久久视精品爱| 久久无码一区二区三区少妇| 天天爽天天爽天天片a久久网| 国产精品免费福利久久| 国产精品一区二区久久不卡|