溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Facebook開源自用工具,可從GitHub獲取

發(fā)布時間:2020-08-07 09:49:20 來源:ITPUB博客 閱讀:234 作者:HitTwice 欄目:服務器

  眾所周知,谷歌對其數(shù)據(jù)中心一直實行著嚴格的保密,不過同屬著名科技公司的Facebook卻不是這樣。近日,這家社交媒體巨頭以開源的方式發(fā)布了兩款重要工具——而這兩款工具曾只在其內(nèi)部使用。

  其一是Katran,這個負載均衡器的作用是使該公司的數(shù)據(jù)中心不會過載,它是GNU通用公共許可證v2.0下的開放源碼,可以從GitHub上獲得。除了Katran之外,該公司還提供了關于Zero Touch Provisioning tool的詳細信息,該工具用于幫助工程師自動化其構建主干網(wǎng)絡時所需的大部分工作。

  這并不是Facebook第一次嘗試開源軟件。上個月,該公司開放了PyTorch的源代碼,這是一款用于人工智能(AI)和機器學習項目的軟件。PyTorch是一個基于python的包,用于編寫張量計算和使用GPU加速的深度神經(jīng)網(wǎng)絡。

  這類軟件包是Facebook必須自主開發(fā)的,盡管市面上有很多現(xiàn)成的軟件產(chǎn)品,但并沒有哪一款是為一家擁有20億用戶的全球社交媒體公司開發(fā)的。

Facebook開源自用工具,可從GitHub獲取

  Facebook負載均衡工具的詳細信息

  這則消息來自Facebook的生產(chǎn)工程師Nikita Shirokov和軟件工程師Ranjeeth Dasineni的博客。兩人表示,該公司此前曾開發(fā)過自己的負載平衡軟件,主要基于開源軟件。四年來,它提供了很好的服務,但隨著時間的流逝,也開始顯示出它的局限性。

  他們寫道,負載均衡器必須滿足四個標準:必須在普通的Linux服務器上運行;與給定服務器上的其他服務共存,消除對專用負載平衡服務器的需求;允許low-disruption維護;儀器安裝和調(diào)試簡單。

  Shirokov和Dasineni說,他們的第一個軟件定義的負載均衡器稱為第四層負載均衡器(Layer 4 load balancer或簡稱L4LB),在與其他服務標準(特別是后端)共存時出現(xiàn)了不足。

  “在第二個迭代中,我們利用了eXpress Data Path (XDP)框架和新的BPF虛擬機(eBPF)來運行軟件負載均衡器,以及大量機器上的后端?!彼麄儗懙?。

  Facebook的零接觸服務開通工具的詳細信息

  Facebook的零接觸服務開通(ZTP,Zero Touch Provisioning) 工具背后的細節(jié)也來自大約三周前Facebook的一些工程師寫的一篇博文。ZTP允許你自動地在你的網(wǎng)絡中提供新的交換機和路由器,不需要人工干預。

  對于像Facebook這樣規(guī)模的公司來說,必須建立自己的網(wǎng)絡,這就是它需要一個ZTP工具的原因。與負載平衡一樣,該公司發(fā)現(xiàn)現(xiàn)有的ZTP工具不足以處理Facebook運行的業(yè)務規(guī)模。

  “最終,這些挑戰(zhàn)促使Facebook的網(wǎng)絡工程師去開發(fā)一種全新的網(wǎng)絡部署工作流方法?!辈┛妥髡哒f。

  因此,它創(chuàng)建了一個名為Vending Machine(“自動售貨機”)的新框架,只是在這里,輸入的是設備角色、位置和平臺,而不是投進去硬幣然后得到一瓶飲料。ZTP仍在發(fā)展中,F(xiàn)acebook也在增加新的功能和功能。

  Facebook尚未披露ZTP的許可證。就像Katran一樣,如果你決定使用這些工具,一切只能靠自己。一個“善良”的Facebook工程師也許會幫助回答一些使用中遇到的問題,但官方也許不會提供支持文檔之類的。所以,筆者也很好奇誰會真正使用這些軟件,因為它們并不是中小型企業(yè)的“菜”。它看起來是為大型企業(yè)設計的,而且多數(shù)大型企業(yè)都有自己的平臺。當然,這個只是一面之詞,不是絕對的。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。

AI