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

            陳碩的Blog

            muduo多機協(xié)作網(wǎng)絡編程示例一:單詞計數(shù)及排序

            去年我寫了《Muduo 網(wǎng)絡編程示例》系列文章,這些文章已經(jīng)收入《Linux 多線程服務端編程:使用 muduo C++ 網(wǎng)絡庫》一書。這些文章講的基本都是運行在單機上的網(wǎng)絡程序,每個例子都只有一個程序(第7.13節(jié)例外)。我接下來打算繼續(xù)寫幾篇文章,談一談分布在多臺機器上、協(xié)作發(fā)揮作用的網(wǎng)絡編程例子。

            今天先講第一個,單詞計數(shù)及排序。單詞計數(shù)(word count),顧名思義就是統(tǒng)計一個文本文件里邊每個詞出現(xiàn)了多少次。排序指的是按出現(xiàn)次數(shù)從多到少排序,也可以把問題改為“找出出現(xiàn)次數(shù)最多的1000個單詞”。

            這個問題有三個層次,第一是輸入文件比較小,能完全放入內(nèi)存;第二是輸入文件比較大,不能一次性都放入內(nèi)存;第三是輸入文件分布在多臺機器上,這需要用到網(wǎng)絡編程。

            第一個層次很好解決,幾十行代碼就搞定了。https://gist.github.com/4519962

            第二個層次不難解決,基本思路是分而治之,先hash分塊統(tǒng)計單詞出現(xiàn)次數(shù),將每一塊按出現(xiàn)次數(shù)排序,最后歸并。代碼見 https://github.com/chenshuo/recipes/blob/master/puzzle/query_freq.cc ,分析見 http://www.cnblogs.com/baiyanhuang/archive/2012/11/11/2764914.html

            第三個層次也不難,可以當做網(wǎng)絡編程的練習來做。如果有合適的框架,可以輕松解決,因為單詞計數(shù)是map reduce的經(jīng)典范例,對出現(xiàn)次數(shù)排序也可以再用一步map reduce搞定(估計需要一個好的 shuffle 函數(shù),簡單hash是不行的)。

            如果用普通網(wǎng)絡編程,一種設計思路如下圖,其中方框代表機器,橢圓代表輸入輸出文件,圓角矩形代表進程。思路跟第二個層次一樣,先hash到多個shard文件(由hasher和receiver負責),再對每個shard文件排序(由sender負責),最后歸并(merger)。

            topk

            注意這種思路適合求top K元素,不適合按出現(xiàn)次數(shù)排序全部單詞,因為最終結(jié)果收集在一臺機器上。目前這個sender實現(xiàn)的一個限制是,每個shard必須能全部放入內(nèi)存,因為sender對shard排序是在內(nèi)存中進行的。如果數(shù)據(jù)更大,還需要實現(xiàn)單機外部排序。

            圖中hasher和receiver的代碼見muduo示例中的 muduo/examples/wordcount ;sender和merger的代碼見 https://github.com/chenshuo/recipes/tree/master/topk 。注意merger沒有使用muduo,而是采用阻塞網(wǎng)絡編程。有興趣的讀者可以思考其背后的原因。要想發(fā)揮 merger 正常的性能,需要修改 /usr/include/boost/asio/basic_socket_streambuf.hpp ,增大緩沖區(qū),即 enum { buffer_size = 8192 };

            這可以看作是map reduce的原始實現(xiàn),或者說用map reduce的思想手寫了一些原始工具。如果把map reduce比作C語言,這里的幾個程序相當于匯編寫的函數(shù)。

            以后我再寫一個按出現(xiàn)次數(shù)全排序的例子吧,需要替換這里的sender和merger。

            (.完.)

            posted on 2013-01-13 04:01 陳碩 閱讀(3594) 評論(2)  編輯 收藏 引用 所屬分類: muduo

            評論

            # re: muduo多機協(xié)作網(wǎng)絡編程示例一:單詞計數(shù)及排序[未登錄] 2013-01-14 10:58 春秋十二月

            不錯,看了代碼,雖沒直接實現(xiàn)Hash、堆和歸并算法,但這沒關(guān)系,使用現(xiàn)成的boost和stl庫也好,你對庫運用的很到位  回復  更多評論   

            # re: muduo多機協(xié)作網(wǎng)絡編程示例一:單詞計數(shù)及排序 2013-01-16 11:38 UCoding

            學習了!  回復  更多評論   

            <2013年1月>
            303112345
            6789101112
            13141516171819
            20212223242526
            272829303112
            3456789

            導航

            統(tǒng)計

            常用鏈接

            隨筆分類

            隨筆檔案

            相冊

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            国内精品久久久久影院薰衣草 | 日本欧美国产精品第一页久久| 久久综合国产乱子伦精品免费| 99精品久久久久久久婷婷| 99久久精品免费看国产一区二区三区 | 99久久婷婷国产一区二区| 大蕉久久伊人中文字幕| 亚洲国产综合久久天堂| 久久精品国产亚洲av影院| 国产精品成人精品久久久| 久久免费看黄a级毛片| 嫩草影院久久99| 亚洲国产欧美国产综合久久| 久久精品国产亚洲网站| 漂亮人妻被中出中文字幕久久 | 久久香蕉国产线看观看乱码| 久久人人爽人人爽人人片AV东京热| 亚洲中文字幕久久精品无码APP| 久久免费高清视频| 亚洲精品蜜桃久久久久久| 亚洲精品高清一二区久久| 中文字幕一区二区三区久久网站| 色狠狠久久综合网| 久久久久久国产精品无码下载| 国产精品久久久久久影院 | 一本一道久久a久久精品综合 | 97精品伊人久久久大香线蕉| 久久久久国产精品嫩草影院| AV无码久久久久不卡网站下载 | 久久久老熟女一区二区三区| 久久久久久久综合狠狠综合| 久久强奷乱码老熟女| 久久国产视频99电影| 亚洲国产精久久久久久久| 久久美女人爽女人爽| 久久综合丁香激情久久| 1000部精品久久久久久久久| 国产麻豆精品久久一二三| 久久91精品国产91久久户| 久久精品国产亚洲沈樵| 国产精品99久久久久久猫咪|