• <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
            數據加載中……

            lighttpd1.4.18代碼分析(七)--狀態機(1)CON_STATE_REQUEST_START狀態

            本節開始分析lighttpd中處理連接的狀態機,也就是connections.c文件中的connection_state_machine函數.我們將沿著上一節中給出的狀態機示意圖一步一步往下走,以圖把這個過程分析清楚.這也是目前為止唯一一個詳細進行分析的函數,希望這樣可以更加突出這個函數的重要性.

            一)CON_STATE_REQUEST_START狀態
            這個狀態出現在剛剛通過accept函數接收一個新的連接時,此時需要保存一些數據:
                    case CON_STATE_REQUEST_START: /* transient, 開始接收請求 */
                        
            if (srv->srvconf.log_state_handling) {
                            log_error_write(srv, __FILE__, __LINE__, 
            "sds",
                                    
            "state for fd", con->fd, connection_get_state(con->state));
                        }

                        
            // 保存時間
                        con->request_start = srv->cur_ts;
                        con
            ->read_idle_ts = srv->cur_ts;

                        
            // 該連接的請求次數
                        con->request_count++;
                        
            // 每次循環處理的請求次數
                        con->loops_per_request = 0;

                        
            // 狀態改為可讀, 也就是可以接收數據
                        connection_set_state(srv, con, CON_STATE_READ);

                        
            /* patch con->conf.is_ssl if the connection is a ssl-socket already */

            #ifdef USE_OPENSSL
                        con
            ->conf.is_ssl = srv_sock->is_ssl;
            #endif

                        
            break;
            需要注意的是這里將connetion中的兩個字段保存為當前時間,request_start和read_idle_ts, 前者存放的是接收連接的時間, 后者用于超時判斷, 在第5節講解lighttpd中如何處理超時的時候提到過,lighttpd設置了一個每一秒一次的定時器, 每次定時器到時就依次輪詢所有的連接, 判斷是否超時, 而判斷的依據就是拿當前的時間 - connection的read_idle_ts字段, 看看是否超時:
             // 如果當前時間與read_idle_ts之差大于max_read_idle, 超時
                                        if (srv->cur_ts - con->read_idle_ts > con->conf.max_read_idle) {
                                            
            /* time - out */

                                            connection_set_state(srv, con, CON_STATE_ERROR);
                                            changed 
            = 1;
                                        }

            這些該保存的數據都保存完畢之后, 狀態機進入下一個狀態,CON_STATE_READ, 也就是開始接收數據, 這是下一節要講解的內容了.


            posted on 2008-09-22 15:10 那誰 閱讀(2937) 評論(0)  編輯 收藏 引用 所屬分類: 網絡編程服務器設計Linux/Unixlighttpd

            伊人久久大香线蕉精品不卡| 91精品国产综合久久精品| 精品久久久久中文字| 久久久网中文字幕| 色狠狠久久AV五月综合| 精品一区二区久久| 一本久久综合亚洲鲁鲁五月天亚洲欧美一区二区 | 精品久久久久久无码国产| 久久久久亚洲精品无码网址| 欧美亚洲国产精品久久久久| 久久综合国产乱子伦精品免费| 久久久久中文字幕| 婷婷久久香蕉五月综合加勒比| 99热都是精品久久久久久| 久久夜色精品国产亚洲| 成人亚洲欧美久久久久| 亚洲国产欧洲综合997久久| 久久久不卡国产精品一区二区 | 狠狠色婷婷综合天天久久丁香| 久久天天躁狠狠躁夜夜av浪潮| 久久香蕉超碰97国产精品| 综合久久一区二区三区 | 伊人久久大香线焦AV综合影院| 久久久精品一区二区三区| 一本色道久久HEZYO无码| 一本久久a久久精品综合夜夜 | 热久久这里只有精品| 97精品国产97久久久久久免费| 老司机午夜网站国内精品久久久久久久久| 久久久亚洲欧洲日产国码aⅴ| 色狠狠久久综合网| 一本色道久久综合狠狠躁篇 | 91视频国产91久久久| 成人妇女免费播放久久久| 久久综合狠狠综合久久综合88| 一本久久a久久精品vr综合| 久久99国产精品久久99小说| 无码国内精品久久人妻麻豆按摩 | 精品永久久福利一区二区| 久久精品国产亚洲AV无码麻豆| 色欲av伊人久久大香线蕉影院|