• <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++博客 首頁 新隨筆 聯系 聚合 管理
              17 Posts :: 2 Stories :: 9 Comments :: 0 Trackbacks

             

             

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

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

             

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

             

            run_sentinel  監聽53端口接收客戶端請求,將請求放到隊列中

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

             

            run_quizzer    

            1.不間斷的遍歷qlist,只要狀態為PROCESS_QUERYdataset中沒有的就向對應的根發送請求。

            2.通過epoll等待根返回,解析返回的數據加入 dataset

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

             

            關于dataset的實現

            dataset是使用哈希表實現的,本質上是個二維數組,將域名哈希成一個值,模上數組的數量作為下標,找到對應的數組接著遍歷查找,根據需要可以擴大數組的數量提升性能。

             

            我們的優化手段

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

             

            以上可以看出dataset很重要,負載也不小,還經常需要并發訪問,這里我們每次接收到根的回復后,除了將記錄的答案加進dataset,還創建一個臨時的dataset,只存該次回復的信息,在后面的流程會優先到這里去找,沒有的再找dataset。

            posted on 2017-01-23 15:14 clcl 閱讀(215) 評論(0)  編輯 收藏 引用
            久久国产精品成人片免费| 99999久久久久久亚洲| 97热久久免费频精品99| www久久久天天com| 国产一区二区久久久| 亚洲香蕉网久久综合影视| 精品国产乱码久久久久久1区2区 | 精品久久无码中文字幕| 精品视频久久久久| 亚洲国产精品无码久久一线| 精品午夜久久福利大片| 青青青青久久精品国产h久久精品五福影院1421 | AV无码久久久久不卡蜜桃| 久久国产精品久久久| 欧美激情精品久久久久久久 | 精品熟女少妇AV免费久久| 国内精品久久久久影院薰衣草 | 久久99国产精品成人欧美| 亚洲第一永久AV网站久久精品男人的天堂AV| 久久久久国产成人精品亚洲午夜| 久久夜色tv网站| 久久人人添人人爽添人人片牛牛 | 久久九九久精品国产| 久久久久久久久久久久久久 | 久久综合色之久久综合| 久久夜色精品国产欧美乱| 国内精品久久久久久麻豆| 久久偷看各类wc女厕嘘嘘| 亚洲综合久久久| 激情五月综合综合久久69| 精品久久久久久综合日本| 亚洲精品乱码久久久久久久久久久久| 久久综合狠狠综合久久激情 | 久久久久无码中| 97久久久久人妻精品专区| 欧美日韩精品久久久免费观看| 久久精品国产国产精品四凭| 激情伊人五月天久久综合| 日本WV一本一道久久香蕉| 亚洲人成电影网站久久| 国产福利电影一区二区三区久久久久成人精品综合|