• <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 那誰 閱讀(5391) 評論(0)  編輯 收藏 引用 所屬分類: 服務器設計Nginx

            青青国产成人久久91网| 久久99国内精品自在现线| 国产精品久久亚洲不卡动漫| 性欧美丰满熟妇XXXX性久久久| 久久久无码人妻精品无码| 久久香蕉综合色一综合色88| 日韩精品久久久久久久电影| 国产69精品久久久久久人妻精品| 久久人人爽人人爽人人片av高请| 久久亚洲国产精品一区二区| 久久只有这里有精品4| 久久精品视频免费| 精品久久久久久国产| 精品久久久无码中文字幕| 人妻久久久一区二区三区| 久久精品二区| 国产69精品久久久久9999| 成人久久免费网站| 欧洲国产伦久久久久久久| 91精品国产91久久综合| 伊人久久大香线蕉AV色婷婷色| 国产精品狼人久久久久影院| 久久久久久午夜成人影院| 久久夜色精品国产噜噜亚洲a| 久久99精品久久久久久水蜜桃| 99精品国产99久久久久久97| 天堂无码久久综合东京热| 久久狠狠色狠狠色综合| 久久天堂AV综合合色蜜桃网| 久久久久久久久久久久久久 | 久久天天躁夜夜躁狠狠| 久久久精品无码专区不卡| 观看 国产综合久久久久鬼色 欧美 亚洲 一区二区 | 久久久久亚洲精品无码蜜桃| 久久婷婷是五月综合色狠狠| 亚洲精品国精品久久99热| 久久国产成人午夜AV影院| 香港aa三级久久三级老师2021国产三级精品三级在 | 久久99精品免费一区二区| 国产99久久久国产精品~~牛| 国产精品久久久久…|