国产一级a片免费看高清,亚洲熟女中文字幕在线视频,黄三级高清在线播放,免费黄色视频在线看

打開APP
userphoto
未登錄

開通VIP,暢享免費(fèi)電子書等14項(xiàng)超值服

開通VIP
Facebook背后的軟件

Facebook的數(shù)據(jù)規(guī)模使得很多傳統(tǒng)的解決方案根本不適用,或者無法分解來處理。保持一個(gè)擁有5億用戶的系統(tǒng)一直穩(wěn)定可靠的運(yùn)行,并不是一件很容易的事情。這篇文章介紹了一下Facebook使用的軟件。

Facebook的擴(kuò)展性挑戰(zhàn)

在我們討論細(xì)節(jié)之前,這里有一些Facebook已經(jīng)做的軟件規(guī)模:

> Facebook有570000000000每月頁(yè)面瀏覽量 (據(jù)Google Ad Planner)。

> Facebook的照片量比其他所有圖片網(wǎng)站加起來還多(包括Flickr等網(wǎng)站)。

> 每個(gè)月超過30億張照片被上傳。

> Facebook的系統(tǒng)服務(wù)每秒處理120萬張照片 。 這不包括CDN服務(wù)中處理的照片。

> 每月超過25億條的內(nèi)容 (狀態(tài)更新,評(píng)論等)被共享。

> Facebook有超過30,000服務(wù)器 (這個(gè)數(shù)字是去年的?。?/p>

Facebook擴(kuò)展所依賴的軟件

Facebook是在某些程度上說仍然是LAMP的站點(diǎn),但它比普通的LAMP大得多,以納入其他元素和很多服務(wù),并修改現(xiàn)行的做法。

例如:

> Facebook也使用PHP,但它已經(jīng)為它建立一個(gè)編譯器,以便它可以分為本地代碼打開了Web服務(wù)器,從而提高性能。

> Facebook也使用Linux,但它特別為網(wǎng)絡(luò)吞吐量做了優(yōu)化。

> Facebook也使用MySQL,但主要是作為一個(gè)Key-value的持久性存儲(chǔ),Jions和服務(wù)器邏輯操作在Web服務(wù)器上操作。因?yàn)樵谀抢锔菀讏?zhí)行。

> 還有是自編寫的系統(tǒng),如Haystack,一個(gè)高度可擴(kuò)展的對(duì)象存儲(chǔ),用來存儲(chǔ)Facebook的照片。還有Scribe,一個(gè)日志系統(tǒng),可以運(yùn)行在Facebook的巨大規(guī)模上的日志系統(tǒng)。

OK?,F(xiàn)在 我們介紹一下全球最大的社會(huì)網(wǎng)絡(luò)網(wǎng)站的所使用的軟件吧。

Memcached

memcached的是現(xiàn)在互聯(lián)網(wǎng)最有名的軟件之一了。 這是一個(gè)分布式內(nèi)存緩存系統(tǒng),用來作為Web服務(wù)器和MySQL服務(wù)器之間的緩存層(因?yàn)閿?shù)據(jù)庫(kù)訪問比較慢)。 多年以來,F(xiàn)acebook已經(jīng)提出了一些優(yōu)化Memcached和一些周邊軟件的辦法。如壓縮network stack。

Facebook的每時(shí)每刻都有數(shù)10TB的數(shù)據(jù)緩存在Memcached的數(shù)千臺(tái)服務(wù)器上。 它可能是世界上最大的Memcached的集群了。

HipHop for PHP

PHP作為一種腳本語(yǔ)言,和本地程序相比是運(yùn)行緩慢的。 HipHop可以將PHP轉(zhuǎn)換成C++代碼,然后再進(jìn)行編譯,可以獲得更好的性能。 因?yàn)镕acebook嚴(yán)重依賴PHP,這使得其可以讓W(xué)eb服務(wù)器運(yùn)行的更有效率。

一個(gè)工程師小團(tuán)隊(duì)在Facebook(一開始只有三人)花了18個(gè)月時(shí)間開發(fā)HipHop,現(xiàn)在已經(jīng)是可用狀態(tài)。

Haystack

Haystack是Facebook的高性能照片存儲(chǔ)/檢索系統(tǒng)(嚴(yán)格來說,是一個(gè)對(duì)象存儲(chǔ),因此它并不一定要存儲(chǔ)照片)。 它有許多工作要做;有超過20億張上傳的照片,并且每一個(gè)被保存在四個(gè)不同的分辨率,因此有超過800億張照片。

它不僅是對(duì)能夠處理的上億的照片,運(yùn)行表現(xiàn)也是至關(guān)重要的。 正如我們前面提到的,F(xiàn)acebook的服務(wù)約120萬張照片每秒 ,這個(gè)數(shù)字不包括CDN上的。 這是一個(gè)驚人的數(shù)字。

BigPipe

BigPipe是Facebook開發(fā)的一個(gè)動(dòng)態(tài)的網(wǎng)頁(yè)服務(wù)系統(tǒng)。 Facebook使用它來按section(稱為“pagelets”)處理每個(gè)網(wǎng)頁(yè),以獲取最佳性能。

例如,在聊天窗口是分開的,新聞Feed也是分開的,等等。 這些pagelets可以在一個(gè)頁(yè)面表現(xiàn)的時(shí)候同時(shí)使用,這是該頁(yè)面表現(xiàn)的時(shí)候獲取進(jìn)來的。即使某些工程的一部分關(guān)閉或中端,用戶也可以獲得一部分網(wǎng)頁(yè)。

Cassandra

Cassandra是一個(gè)不會(huì)單點(diǎn)失敗的分布式存儲(chǔ)系統(tǒng)。 這是為NoSQL運(yùn)動(dòng)的一個(gè)重要組成部分,并已公開的源代碼(它甚至成為一個(gè)Apache項(xiàng)目)。Facebook在搜索功能中使用它。

除了Facebook,還有一些人也用它,例如Digg的。 不過最近Twitter放棄了cassandra。

Scribe

Scribe是一個(gè)靈活的日志系統(tǒng),F(xiàn)acebook在他的內(nèi)部大量使用。 它的能夠處理在Facebook的大規(guī)模日志記錄,并自動(dòng)處理新的日志記錄類別,Facebook有數(shù)百個(gè)日志類別(categories)。

Hadoop and Hive

Hadoop的是一個(gè)開源的map-reduce實(shí)現(xiàn),使得它可以在進(jìn)行大數(shù)據(jù)上進(jìn)行運(yùn)算。 Facebook的使用這個(gè)進(jìn)行數(shù)據(jù)分析(而我們都知道,F(xiàn)acebook已經(jīng)大量的數(shù)據(jù))。 Hive就是發(fā)源于Facebook,使得對(duì)于Hadoop使用的SQL查詢成為可能,從而是其更容易對(duì)非程序員使用。

Hadoop和Hive是開源的(Apache項(xiàng)目),有為數(shù)眾多的追隨者,例如雅虎和Twitter。

Thrift

Facebook使用的幾種不同的語(yǔ)言和不同的services。 PHP是最終用于前端,Erlang是用于聊天,Java和C ++也使用于多種場(chǎng)所,也許還有其他語(yǔ)言。Thrift是一個(gè)內(nèi)部開發(fā)的跨語(yǔ)言的框架,聯(lián)系語(yǔ)言,使他們可以在一起合作,從而使他們之間可以交互。 這使得Facebook可以更容易為繼續(xù)保持其跨語(yǔ)言的發(fā)展。

Facebook已經(jīng)讓Thrift開源。更多的語(yǔ)言支持已被添加到Thrift。

Varnish

Varnish是一個(gè)HTTP加速器,可以作為一個(gè)負(fù)載平衡器,并緩存的內(nèi)容,然后可以以閃電般的速度送達(dá)。

Facebook使用的arnish來處理照片和個(gè)人資料圖片,處理每天數(shù)十億的要求。 和其他的東西一樣,Varnish是開源的。

保持Facebook 順暢運(yùn)行的其他東西。

我們已經(jīng)提到的軟件,組成了Facebook的系統(tǒng),并幫助運(yùn)行在大規(guī)模上。 但是,處理這么大的系統(tǒng)是一個(gè)復(fù)雜的任務(wù),因此我們將列出一些其他的東西,他們保持了Facebook的平穩(wěn)運(yùn)行。

漸進(jìn)發(fā)布和暗啟動(dòng)

Facebook有一個(gè)他們所謂的守門人制度(Gatekeeper),允許他們可以給不同的用戶運(yùn)行兩套不同的系統(tǒng)。 這讓Facebook漸進(jìn)的發(fā)布新的功能,A / B測(cè)試,只為Facebook雇員發(fā)布等的某些特性。
Gatekeeper也可以讓Facebook實(shí)現(xiàn)“暗啟動(dòng)”,這是在用戶使用一些功能之前,就激活某些功能(因?yàn)橛脩魶]有察覺,所以稱之為暗啟動(dòng))。 這將作為一個(gè)現(xiàn)實(shí)世界的壓力測(cè)試,在正式啟動(dòng)前,幫助揭露一些功能障礙和其他問題。 暗啟動(dòng)通常是在正式啟動(dòng)前兩個(gè)星期。

Profiling的直播系統(tǒng)

Facebook的仔細(xì)監(jiān)控其系統(tǒng),有趣的是它也負(fù)責(zé)監(jiān)察每一個(gè)PHP函數(shù)在生產(chǎn)環(huán)境的性能。 檢測(cè)各個(gè)PHP的環(huán)境的配置運(yùn)行情況。使用開源工具,XHProf 。

漸進(jìn)的利用關(guān)閉功能來提升性能

如果Facebook運(yùn)行時(shí)出現(xiàn)性能問題,有一個(gè)辦法,就是逐步禁用不太重要的功能,以增強(qiáng)Facebook的大量核心功能表現(xiàn)。

我們沒有提及的事情

我們沒有提到硬件相關(guān)的事情,但這也是提高可伸縮性的重要一環(huán)。例如,就像其他大型站點(diǎn),F(xiàn)acebook利用CDN來處理靜態(tài)內(nèi)容。Facebook還有一個(gè)the huge data center,可以幫助他擴(kuò)展更多的服務(wù)。

Facebook的開源情節(jié)

不僅是Facebook使用(和幫助),如Linux,Memcached的,MySQL和Hadoop的開源軟件,以及許多其他情況下,也貢獻(xiàn)許多了其內(nèi)部開發(fā)的軟件。

Facebook亦開源了Tornado,一個(gè)高性能的網(wǎng)絡(luò)服務(wù)器框架,由FriendFeed團(tuán)隊(duì)開發(fā)。

關(guān)于開放源碼軟件清單,可以在Facebook’s Open Source page找到。

本文來自:顏開的博客——我自然

原文標(biāo)題:Facebook背后的軟件

譯文鏈接:http://www.yankay.com/

原文鏈接:http://royal.pingdom.com/2010/06/18/the-software-behind-facebook/

本站僅提供存儲(chǔ)服務(wù),所有內(nèi)容均由用戶發(fā)布,如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊舉報(bào)。
打開APP,閱讀全文并永久保存 查看更多類似文章
猜你喜歡
類似文章
揭秘全球最大網(wǎng)站Facebook背后的那些軟件
揭秘Facebook的系統(tǒng)架構(gòu) - CSDN.NET - CSDN軟件研發(fā)頻道
大數(shù)據(jù)概述
Facebook 的 PHP 性能與擴(kuò)展性
信息平臺(tái)和數(shù)據(jù)科學(xué)家的興起
Hypertable應(yīng)用實(shí)踐
更多類似文章 >>
生活服務(wù)
分享 收藏 導(dǎo)長(zhǎng)圖 關(guān)注 下載文章
綁定賬號(hào)成功
后續(xù)可登錄賬號(hào)暢享VIP特權(quán)!
如果VIP功能使用有故障,
可點(diǎn)擊這里聯(lián)系客服!

聯(lián)系客服