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

            xiaoxiaoling

            C++博客 首頁 新隨筆 聯(lián)系 聚合 管理
              17 Posts :: 2 Stories :: 9 Comments :: 0 Trackbacks

             

             

            dns的遞歸解析過程還是挺繁瑣的,要知道一個(gè)域名可能有cname、ns 而請求的cname、ns可能還有cname、ns,如果按照線性的處理每個(gè)請求那邏輯就變成毛線團(tuán)了

            dnspod的處理還是挺巧妙的,通過一個(gè)公共的數(shù)據(jù)集dataset將所有域名對應(yīng)的a、cname、ns等類型的數(shù)據(jù)作為單獨(dú)的條目存入,當(dāng)有需要某個(gè)域名的信息時(shí)先去dataset找,找不到在加入qlist請求根,有專門的線程不間斷的將qlist輪詢dataset找(這里只要次數(shù)允許,沒得到想要的結(jié)果就輪詢所有qlist到dataset找雖然可以簡化邏輯分離的徹底但是會(huì)是個(gè)性能瓶頸,后面有方案)當(dāng)根返回以后只是簡單的將記錄(通常是一個(gè)域名的cname、ns或者a)存入dataset(而不是繼續(xù)流程,因?yàn)楦鶕?jù)這個(gè)返回是cname還是ns或者a處理不同邏輯復(fù)雜,而這樣處理對于用到相同域名的請求還有優(yōu)化作用),剩下的工作交給那邊不間斷輪詢的線程

             

            Dnspod主要由3個(gè)run(若干個(gè)線程)組成

             

            run_sentinel  監(jiān)聽53端口接收客戶端請求,將請求放到隊(duì)列中

            run_fetcher   從隊(duì)列中取出請求,根據(jù)qname取得最后一級(jí)cname,查看本地dataset 是否有記錄,如果有則返回,沒有則將該請求放入qlist中

             

            run_quizzer    

            1.不間斷的遍歷qlist,只要狀態(tài)為PROCESS_QUERYdataset中沒有的就向?qū)?yīng)的根發(fā)送請求。

            2.通過epoll等待根返回,解析返回的數(shù)據(jù)加入 dataset

            3.檢查記錄的ttl,在將記錄加入dataset時(shí)還會(huì)將這些記錄以紅黑樹的形式組織起來,取得ttl最早到期的,將其放入qlist中等待刷新,注意這里不是刪除,如果收不到不返回則該記錄一直存在

             

            關(guān)于dataset的實(shí)現(xiàn)

            dataset是使用哈希表實(shí)現(xiàn)的,本質(zhì)上是個(gè)二維數(shù)組,將域名哈希成一個(gè)值,模上數(shù)組的數(shù)量作為下標(biāo),找到對應(yīng)的數(shù)組接著遍歷查找,根據(jù)需要可以擴(kuò)大數(shù)組的數(shù)量提升性能。

             

            我們的優(yōu)化手段

            之前提到dnspod的qlist會(huì)不間斷輪詢,屬于主動(dòng)查詢,對性能有不小的影響,這里我們采取的做法是被動(dòng)(類似回調(diào)的方式),我們將請求的域名和類型分類,相同的放在一組,當(dāng)dataset找不到向根發(fā)出請求后我們并不每次主動(dòng)輪詢,而是在等到應(yīng)答后,觸發(fā)該域名和類型的請求組,讓他們根據(jù)自己的邏輯走下一步(一般是先找該域名的最后一級(jí)cname,根據(jù)這個(gè)cname查是否存在他的對應(yīng)請求類型的記錄,一般是a或者ns,如果沒有,則找這個(gè)cname的ns)

             

            以上可以看出dataset很重要,負(fù)載也不小,還經(jīng)常需要并發(fā)訪問,這里我們每次接收到根的回復(fù)后,除了將記錄的答案加進(jìn)dataset,還創(chuàng)建一個(gè)臨時(shí)的dataset,只存該次回復(fù)的信息,在后面的流程會(huì)優(yōu)先到這里去找,沒有的再找dataset。

            posted on 2017-01-23 15:14 clcl 閱讀(209) 評(píng)論(0)  編輯 收藏 引用
            亚洲日本va中文字幕久久| 久久久久亚洲AV成人网人人网站 | 亚洲欧洲久久久精品| 久久久久亚洲AV成人网人人网站| 精品伊人久久久| 久久久久一区二区三区| 色婷婷综合久久久久中文字幕| 久久综合精品国产二区无码| 久久久久无码精品国产app| 中文字幕无码免费久久| 久久国产高清一区二区三区| 久久er99热精品一区二区| 久久久久九九精品影院| 91精品国产91久久综合| 国产69精品久久久久APP下载| 99久久精品免费看国产免费| 久久综合给合久久狠狠狠97色69 | 少妇精品久久久一区二区三区| 久久精品一区二区三区不卡| 97精品依人久久久大香线蕉97| 精品久久久久久国产三级 | 亚洲精品无码久久久影院相关影片| 日本一区精品久久久久影院| 亚洲午夜久久久久妓女影院| 人妻无码精品久久亚瑟影视| 97精品国产97久久久久久免费| 久久精品www人人爽人人| 亚洲精品97久久中文字幕无码| 97久久精品人人做人人爽| 东京热TOKYO综合久久精品| 狠狠色综合网站久久久久久久高清 | 久久精品久久久久观看99水蜜桃| 久久成人18免费网站| 久久综合综合久久97色| 精品999久久久久久中文字幕| 欧美丰满熟妇BBB久久久| 欧美喷潮久久久XXXXx| 久久精品国产亚洲AV麻豆网站| 久久久噜噜噜久久中文福利| 亚洲国产精品无码久久SM| 少妇久久久久久被弄高潮|