一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

腳本之家,腳本語言編程技術(shù)及教程分享平臺!
分類導(dǎo)航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務(wù)器之家 - 腳本之家 - Ruby - Ruby中的類Google Map/Reduce框架Skynet介紹

Ruby中的類Google Map/Reduce框架Skynet介紹

2020-04-20 12:11腳本之家 Ruby

這篇文章主要介紹了Ruby中的類Google Map/Reduce框架Skynet介紹,Skynet是一款創(chuàng)建分布式應(yīng)用程序的框架,需要的朋友可以參考下

Skynet是一個很響亮的名字,因為它是阿諾施瓦辛格主演的經(jīng)典系列電影《終結(jié)者》里面的統(tǒng)治人類的超級計算機網(wǎng)絡(luò)。不過本文的Skynet沒這么恐怖,它是一個ruby版本的Google Map/Reduce框架的名字而已。

Google的Map/Reduce框架實在太有名氣了,他可以把一個任務(wù)切分為很多份,交給n臺計算機并行執(zhí)行,返回的結(jié)果再并行的歸并,最后得到運算的結(jié)果。據(jù)說Google一個搜索結(jié)果會Map到7000臺服務(wù)器并行執(zhí)行,這么多么可怕的分布式運算能力阿!有了Map/Reduce,程序員就可以在無需關(guān)注分布式框架的情況下,用簡單的代碼寫出來健壯、并行的分布式應(yīng)用程序,并且可以充分發(fā)揮計算機群集運算的能力。

如今能夠?qū)崿F(xiàn)Map/Reduce算法的框架已經(jīng)有好幾個了,其中最有名氣的可能就是Yahoo發(fā)起的開源項目Hadoop,不過Hadoop并不是用ruby編寫的,但在ruby的世界,Adam Pisoni已經(jīng)開發(fā)出來了ruby版本的Map/Reduce框架,這就是Skynet。

Adam Pisoni開發(fā)Skynet的初衷是因為Adam Pisoni的公司Geni.com是一家定位于家族SNS的互聯(lián)網(wǎng)網(wǎng)站。網(wǎng)站提供的新聞推送功能要求能夠從大量的用戶產(chǎn)生的信息當中提取特定用戶感興趣的內(nèi)容,推送給用戶。這實際上是一個分布式運算模型,要能夠把任務(wù)分布到多臺服務(wù)器上面執(zhí)行,最后把任務(wù)歸并回來。Adam Pisoni沒有找到合適的框架,最終自己開發(fā)了Skynet,運用Map/Reduce算法來提供這個分布式運算平臺。

用Skynet開發(fā)Map/Reduce的分布式應(yīng)用程序非常簡單,讓我們舉一個簡單的例子看看吧:假設(shè)有一個1GB的文本文件,我們的任務(wù)是要統(tǒng)計該文件當中每個單詞出現(xiàn)的次數(shù)統(tǒng)計。傳統(tǒng)的做法當然很簡單,順序讀入文件內(nèi)容,進行單詞統(tǒng)計就行了,但是毫無疑問,執(zhí)行速度會很慢。如果我們有一個1000臺服務(wù)器的運算群集,我們可以如何利用Skeynet來并發(fā)執(zhí)行這個程序,從而縮短統(tǒng)計時間呢?

Map/Reduce算法的過程是:

1、Partition(劃分數(shù)據(jù))
把數(shù)據(jù)劃分為1000份,這個過程由Skynet自動完成

2、Map
除了劃分數(shù)據(jù),還需要把運算該數(shù)據(jù)的代碼也Map到每個運算節(jié)點上面去并發(fā)執(zhí)行。這1000個節(jié)點各自執(zhí)行自己的任務(wù),執(zhí)行完畢以后把執(zhí)行結(jié)果返回

3、Partition
這1000分執(zhí)行結(jié)果需要歸并,于是我們再次劃分數(shù)據(jù),比方說劃分為10份,這個過程也是Skynet自動完成的

4、Reduce
把Reduce代碼和Reduce數(shù)據(jù)分發(fā)到10個節(jié)點執(zhí)行,每個節(jié)點執(zhí)行完畢返回數(shù)據(jù)。如果需要再次Reduce可以再次執(zhí)行。最終Reduce為一個總共的結(jié)果。

其實Map/Reduce算法的原理是很簡單的,好了,看看Skynet下面,我們怎么實現(xiàn)呢?其實我們需要編寫的代碼只有兩個方法:一個map方法,告訴skynet如何執(zhí)行每份數(shù)據(jù),一個reduce方法,告訴skynet如何歸并每份數(shù)據(jù),所以這個并行算法最終用Skynet來寫的話,也非常簡單:

復(fù)制代碼 代碼如下:

  class MapreduceTest
    include SkynetDebugger
           
    def self.map(datas)
      results = {}
      datas.each do |data|
        results[data] ||= 0
        results[data] += 1
      end                
      [results]     
    end
   
    def self.reduce(datas)
      results = {}
      datas.each do |hashes|
        hashes.each do |key,value|
          results[key] ||= 0
          results[key] += value
        end
      end
      results
    end
  end

 

這個就是一個最簡單、但是完整ruby版本的Map/Reduce代碼了。我們需要編寫一個map方法,告訴skynet去統(tǒng)計每個單詞的出現(xiàn)次數(shù),我們還需要編寫一個reduce方法告訴skynet去歸并每個map的統(tǒng)計結(jié)果。好了,剩下所有的工作都歸Skeynet接管了,是不是很簡單!

當然要讓這個Map/Reduce跑起來我們還需要做一些工作,比方說安裝skynet,配置skynet的并行節(jié)點等等,這些瑣碎的工作可以看看skynet自己的文檔:http://skynet.rubyforge.org/doc/index.html,就不詳述了。

值得一提的是Skynet可以和Rails框架良好的整合起來工作,你可以把Rails當中一些非常耗時、可以Map/Reduce的工作丟給Skynet去異步后臺執(zhí)行,比方說:

復(fù)制代碼 代碼如下:

MyModel.distributed_find(:all, :conditions => “created_on < '#{3.days.ago}'”).each(:some_method)

 

把最近3天以來所有的model查詢處理以后要執(zhí)行的耗時操作some_method交給Skynet,讓Skynet動用他強大的運算網(wǎng)絡(luò)去執(zhí)行。

還可以異步執(zhí)行:

復(fù)制代碼 代碼如下:

model_object.send_later(:method, options, :save) 

 

把耗時的任務(wù)交給Skynet去異步執(zhí)行。

對于擁有強大運算網(wǎng)絡(luò)、并且需要進行大量耗時運算的web2.0網(wǎng)站來說,Skynet真是一個很棒的工具,他可以讓程序員很簡單的編寫處理健壯而高效的分布式應(yīng)用程序!

延伸 · 閱讀

精彩推薦
  • RubyRuby設(shè)計模式編程中使用Builder建造者模式的實例

    Ruby設(shè)計模式編程中使用Builder建造者模式的實例

    這篇文章主要介紹了Ruby設(shè)計模式編程中使用Builder建造者模式的實例,建造者模式將一個復(fù)雜對象的構(gòu)造與它的表示分離,使同樣的構(gòu)建過程可以創(chuàng)建不同的表...

    范孝鵬2192020-05-07
  • RubyRuby迭代器的7種技巧分享

    Ruby迭代器的7種技巧分享

    這篇文章主要介紹了Ruby迭代器的7種技巧分享,Ruby中的迭代器非常人性化,本文既是講解了7個技巧也是講解了7種迭代器,需要的朋友可以參考下 ...

    腳本之家4782020-04-20
  • RubyRuby進行文件信息輸出實例代碼

    Ruby進行文件信息輸出實例代碼

    Ruby進行文件信息輸出實例代碼,數(shù)據(jù)是隨機的,所以每次的記錄都會不同。 ...

    ruby教程網(wǎng)2962020-04-10
  • Ruby剖析 Ruby 訪問控制

    剖析 Ruby 訪問控制

    前面,我們說 Ruby 沒有函數(shù),只有方法.而且實際上有不止一種方法.這一節(jié)我們介紹 訪問控制 (accesscontrols). 想想當我們在最高層而不是在一個類的定義里定義...

    ruby教程網(wǎng)3572020-04-08
  • RubyRuby環(huán)境下安裝使用bundler來管理多版本的gem

    Ruby環(huán)境下安裝使用bundler來管理多版本的gem

    這篇文章主要介紹了Ruby環(huán)境下安裝使用bundler來管理多版本的gem的方法,舉了Ruby On Rails中的應(yīng)用實例來進行演示,需要的朋友可以參考下 ...

    日拱一卒4332020-05-10
  • RubyRuby簡潔學(xué)習(xí)筆記(一):字符串、數(shù)字、類和對象

    Ruby簡潔學(xué)習(xí)筆記(一):字符串、數(shù)字、類和對象

    這篇文章主要介紹了Ruby簡潔學(xué)習(xí)筆記(一):字符串、數(shù)字、類和對象,本文是學(xué)習(xí)筆記第一篇,需要的朋友可以參考下 ...

    腳本之家2472020-04-20
  • Ruby簡要說明Ruby中的迭代器

    簡要說明Ruby中的迭代器

    這篇文章主要介紹了Ruby中的迭代器,迭代器的概念在動態(tài)語言的編程中十分重要,文章中介紹了Ruby中的each迭代器和collect迭代器,需要的朋友可以參考下 ...

    goldensun2772020-04-25
  • RubyCentOS中配置Ruby on Rails環(huán)境

    CentOS中配置Ruby on Rails環(huán)境

    經(jīng)過一個上午的折騰,終于把ROR環(huán)境在CentOS中搞定,繞了很多彎路,把文章寫下來總結(jié)一下 ...

    可樂加糖4762020-04-12
主站蜘蛛池模板: 韩国禁片在线观看久 | 色综合亚洲精品激情狠狠 | 国产a免费观看 | 久久成人国产精品一区二区 | 把女的下面扒开添视频 | 欧美一级高清免费a | 日韩精品亚洲一级在线观看 | 女同久久另类99精品国产 | 日本人成大片在线 | 亚洲福利一区二区精品秒拍 | 亚洲阿v天堂2018在线观看 | 国产91素人搭讪系列天堂 | 国内激情自拍 | 亚洲国产精久久久久久久 | 99精品视频免费在线观看 | 欧美在线成人免费国产 | 1024亚洲天堂 | xxxx成人| 亚洲第一综合天堂另类专 | 暖暖 免费 高清 日本 在线 | 无遮挡免费h肉动漫在线观看 | 人人艹在线视频 | 办公室出轨秘书高h | 色五月天天 | 99视频免费在线观看 | 久久不射电影网 | 美女扒开腿让男人桶爽免费gif | 国产午夜精品一区二区三区不卡 | 欧美在线视频免费播放 | 国产另类视频一区二区三区 | 翁息肉小说老扒 | 果冻传媒在线视频播放观看 | 美女脱了内裤打开腿让人羞羞软件 | 边摸边吃奶边做爽gif动态图 | 亚洲国产欧美目韩成人综合 | 精品国产乱码久久久久久人妻 | 久久亚洲电影www电影网 | 9966国产精品视频 | 国产成人综合亚洲亚洲欧美 | 日本免费精品 | 欧美视频一级 |