• <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>

            Benjamin

            靜以修身,儉以養德,非澹薄無以明志,非寧靜無以致遠。
            隨筆 - 398, 文章 - 0, 評論 - 196, 引用 - 0
            數據加載中……

            bind源碼解析(二)

              bind9運行主要是兩個線程和一個do while循環,這三部分構成了bind的核心代碼。
            do {
                       result = isc_app_run();
                       if (result == ISC_R_RELOAD) {
                             ns_server_reloadwanted(ns_g_server);
                       } else if (result != ISC_R_SUCCESS) {
                             UNEXPECTED_ERROR(__FILE__, __LINE__,
                                    "isc_app_run(): %s",
                
                        isc_result_totext(result));
                             
            /*
                             
            * Force exit.
                             
            */
                             result = ISC_R_SUCCESS;
                      }
            } while (result != ISC_R_SUCCESS);

            這個do while循環,主要是result = isc_app_run();這個函數實際上等待各種結束程序信號,如果需要重啟服務,就調用ns_server_reloadwanted

            setup函數里中的create_managersvoid)里,有兩個函數要注意
            isc_taskmgr_createisc_socketmgr_create2這兩個函數分別起兩個線程,分別是runwatch

            下面是watch中的關鍵代碼就是
            cc = epoll_wait(manager->epoll_fd, manager->events,
            done = process_fds(manager, manager->events, cc)這兩句代碼一看就知道是處理epool的。它是在isc_socketmgr_create2中的
            if (isc_thread_create(watcher, manager, &manager->watcher) !=ISC_R_SUCCESS)中起的線程;process_fds執行到最后就是isc_task_send(ev->ev_sender, (isc_event_t **)&iev);這個函數執行完就會轉到下面的run線程函數中。process_fd是具體的業務處理,process_ctlfd這個函數雖然不起眼但是很重要,在這個函數中有  wakeup_socket,里面最重要的就是result = watch_fd(manager, fd, msg);,在watch_fd中,關鍵代碼就是epoll_ctl(manager->epoll_fd, EPOLL_CTL_ADD, fd, &event),這里重新注冊時間,然后epool_wait再等待,而后再處理,如此反復。

            result = isc_taskmgr_create(ns_g_mctx, ns_g_cpus, 0, &ns_g_taskmgr)#define isc_taskmgr_create  isc__taskmgr_create,所以這里實際調用的是isc__taskmgr_create,這個函數里if (isc_thread_create(run, manager,&manager->threads[manager->workers])這里啟動run線程函數,run主要執行的代碼就是dispatch(manager)dispath主要執行的是(event->ev_action)( (isc_task_t *)task,event);ev->ev_action其實就是個函數指針;從這里可以看出,bind的處理模式和windows的消息處理機制很相似。
             

            bindepoll采用的是ET模式,邊沿觸發;只對新到的數據進行通知而內核緩沖區中如果是舊數據則不進行通知,每次epoll_wait后,處理完畢后再調用epoll_ctl;這里實際是個循環處理過程,epoll_wait等待,然后加入到events數組中,然后處理,在調用cpoll_ctrl重新設置事件類型,再等待,如此循環。在bind中,sokcet.c中的線程函數watcher中有epooll_wait函數,在啟動這個線程函數前在setup_watcher(isc_mem_t *mctx, isc__socketmgr_t *manager) 這個函數中已經調用了epoll_create

            posted on 2011-03-10 21:10 Benjamin 閱讀(3236) 評論(2)  編輯 收藏 引用 所屬分類: linux

            評論

            # re: bind源碼解析(二)  回復  更多評論   

            你好,我目前想找一下關于BIND里面的查詢算法的代碼。也就是在客戶端提交給DNS服務器之后,服務器是怎么在數據庫里面來查找然后返回結果給客戶端的。請問這個在哪里面呢?請問你有沒有寫過筆記呢?謝謝!期待回復!
            2012-06-10 16:12 | wujierd

            # re: bind源碼解析(二)  回復  更多評論   

            同問樓上的問題,以及怎么讀取的配置文件呢?求回復~謝謝了~
            2015-07-23 15:23 | qjj
            亚洲国产成人久久综合野外| 无码伊人66久久大杳蕉网站谷歌 | 亚州日韩精品专区久久久| 热久久国产欧美一区二区精品| 欧美午夜A∨大片久久 | 国产视频久久| 婷婷久久久亚洲欧洲日产国码AV| 久久最新精品国产| 热re99久久6国产精品免费| 国产福利电影一区二区三区久久久久成人精品综合 | 狠狠色狠狠色综合久久| 国产无套内射久久久国产| 久久天天躁狠狠躁夜夜网站| 久久91精品综合国产首页| 99re这里只有精品热久久| 人妻无码精品久久亚瑟影视| 99久久精品国产综合一区| 婷婷久久香蕉五月综合加勒比| 久久国产成人午夜AV影院| 精品一区二区久久| 亚洲国产精品久久久天堂| 久久毛片一区二区| 亚洲精品乱码久久久久久蜜桃| 久久r热这里有精品视频| 久久婷婷五月综合97色一本一本| 欧美一级久久久久久久大| 婷婷综合久久狠狠色99h| 亚洲国产精品久久久天堂 | 狠狠色丁香久久婷婷综合五月| 思思久久99热免费精品6| 国产精品久久成人影院| 久久久久99精品成人片欧美| 久久偷看各类wc女厕嘘嘘| 久久精品无码一区二区无码| 亚洲乱码精品久久久久..| 国产色综合久久无码有码| 久久WWW免费人成一看片| 亚洲精品乱码久久久久久蜜桃图片 | 亚洲中文字幕无码久久2020| 亚洲综合精品香蕉久久网| 久久亚洲中文字幕精品有坂深雪 |