• <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內核
            隨筆 - 210, 文章 - 0, 評論 - 1183, 引用 - 0
            數據加載中……

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

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

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

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

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

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




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

            精品国产婷婷久久久| 久久久久久久女国产乱让韩| 色综合久久精品中文字幕首页 | 亚洲国产精品久久久久久| 国产叼嘿久久精品久久| 一本一道久久综合狠狠老| 嫩草影院久久99| 久久亚洲精品成人无码网站| 99久久无色码中文字幕| 欧美成人免费观看久久| 久久99国产精一区二区三区| 久久99九九国产免费看小说| 国产成人久久AV免费| 亚洲精品国产综合久久一线| 99国产欧美精品久久久蜜芽| 久久亚洲精品国产精品婷婷| 99热精品久久只有精品| 久久99精品国产自在现线小黄鸭 | 国产aⅴ激情无码久久| 国产2021久久精品| 久久免费线看线看| 精品综合久久久久久98| 青青青青久久精品国产h| 久久综合久久自在自线精品自| 亚洲国产婷婷香蕉久久久久久 | 99久久夜色精品国产网站| 手机看片久久高清国产日韩 | 久久精品国产福利国产琪琪| 久久99国产精一区二区三区| 91精品国产高清91久久久久久| 亚洲精品乱码久久久久久蜜桃不卡 | 久久久精品2019免费观看| 青青草原综合久久大伊人| 久久久久人妻一区精品| 久久亚洲精品无码播放| 久久免费视频6| 国产精品va久久久久久久| 久久久久九九精品影院| 欧洲性大片xxxxx久久久| 免费一级做a爰片久久毛片潮| 欧美精品一本久久男人的天堂|