亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 網站 > 建站經驗 > 正文

解析Instagram網站的圖片存儲架構

2024-04-25 20:46:36
字體:
來源:轉載
供稿:網友

這篇文章主要介紹了Instagram網站的圖片存儲架構,主要由Python的Django驅動的Instagram后臺在PostgreSQL和Redis數據存儲的使用方面同樣亮點頗多,需要的朋友可以參考下

被Facebook以10億美金收購的著名手機照片分享應用Instagram最近吸引了無數人的眼球,Instagram聯合創始人Mike Krieger說他們用了8周時間打造了最初的Instagram,但現在的系統肯定已經今非昔比。Instagram技術團隊曾發表過一篇文章,介紹了Instagram背后的技術,日前Mike Krieger在名為Scaling Instagram的演講里,又介紹了更多細節,讓人們能了解到5名技術人員是如何支撐起整個系統的。

一張照片上傳的過程是這樣的:

1.采用同步的方式寫入媒體數據庫

2.如果照片上有地理位置標簽,則以異步的方式將照片提交給Solr進行索引

3.將照片的ID加入每個關注者的列表里,該列表保存在Redis之中

4.在顯示Feed時,選取一小部分照片ID,在Memcached里進行查詢

5.在設計系統時,Instagram的設計哲學是簡單、為最小化運維負擔進行優化并監控一切內容;其核心原則是保持簡單,不要重復發明輪子,盡可能使用經過驗證、穩定可靠的技術。

由于只有5名技術人員(其中僅2.5名后端工程師),精力有限,選擇Amazon的云服務是個不錯的選擇。目前他們使用了超過100個EC2實例用于提供各種服務,運行的操作系統是Ubuntu 11.04,之前的一些版本在高流量時表現不夠穩定。在負載均衡方面,他們使用Amazon的Elastic Load Balancer實現負載均衡,后端運行了3個Nginx實例,SSL只到ELB上為止,降低了Nginx上的CPU負載。DNS和CDN分別由Amazon的Route 53和CloudFront提供,所有的照片都存放在S3上,目前已經有幾TB的規模了。

用于處理請求的應用服務器運行于Amazon High-CPU Extra-Large Instance之上,由于他們的請求更多是CPU密集型的,因此這能更好地平衡CPU與內存。采用的開發框架是Django,WSGI服務器是Gunicorn,通過Fabric在所有機器上進行并行部署,一次部署僅需幾秒鐘。

用戶信息、圖片元數據、標簽等大部分數據存儲在 PostgreSQL 中。

實踐中發現 Amazon 的網絡磁盤系統單位時間內尋道能力不行,所以有必要將數據盡量放到內存中。創建了軟 RAID 以提升 IO 能力,使用的 Mdadm 工具進行 RAID 管理。

管理內存中的數據,vmtouch 這個小工具值得推薦。

PostgreSQL 設置為 Master-Replica 方式,流復制模式。利用 EBS 的快照進行數據庫備份。使用 XFS 文件系統,以便和快照服務充分配合。 使用 repmgr 這個小工具做 PostgreSQL 復制管理器器。

連接池管理,用了 Pgbouncer。Christophe Pettus 的文章包含了不少 PostgreSQL 數據庫的信息。

應用程序在連接數據庫時,由Pgbouncer建立連接池。目前,Instagram的數據按照用戶ID進行分片,某些分片可能會超出物理節點的容量上限,為此他們將數據分成了很多個邏輯分片,映射到少數幾個物理節點之上;當一個節點被填滿之后,可以將某些邏輯分片移到別的節點上,以緩解該節點的壓力。隨著數據量的增長,以后他們也會進行垂直分區,Django DB Router能讓一切輕松不少。

Instagram也大量使用Redis來存放復雜的對象(對象的大小做了一定的限制),用于主Feed、活動Feed、會話系統及其他相關系統。因為要將Redis的所有數據都放在內存里,此處同樣也用了High-Memory Quadruple Extra-Large Instance,并對數據做了分片。當Redis實例的請求達到4萬/秒后,它漸漸成為了瓶頸,于是Redis也做了主從復制,副本的數據會經常導出到磁盤上,通過EBS快照進行備份。

除了Redis,他們還使用Memcached來做緩存,目前運行了6個實例,應用服務器通過pylibmc和libmemcached進行連接。雖然Amazon提供了Elastic Cache服務,但該服務的價格并不便宜,相比之下,還是運行自己的Memcached實例比較劃算。異步任務隊列使用的是Gearman,目前有大約200個工作進程來處理各種任務,比如把照片分享到Twitter和Facebook,通知用戶有新照片等等。Pyapns已經處理了十億的推送通知,非常穩定,他們還自己開發了基于Node.js的node2dm,用于向Android設備發送推送通知。

監控方面,Instagram使用Munin以圖形化的方式呈現整個系統的運行狀況,還通過Python-Munin定制了一些插件,用來顯示業務數據;網絡守護進程Stated可以實時收集數據并做匯總;Dogslow會監控進程,一旦發現運行時間過長的進程,便會保存該進程的快照,以便后續分析,比如響應時間超過1.5秒的請求,通常都是卡在Memcached的set()和get_many()方法上。對于Python的錯誤,只要登上Sentry就能實時獲取錯誤信息。

HighScalability上還根據整理Instagram團隊軟件工程師Mike Krieger的演講整理了一些值得借鑒的經驗,比如:

1.找那些你熟悉的技術和工具,在簡單的使用場景里先做一些嘗試

2.不要使用兩個工具來處理同樣的任務

3.事先準備降級方案,以便在需要時降低負載

4.不要過度優化,或者希望能事先知道站點要擴展,對于一個初創的社交站點而言,沒什么擴展性問題是解決不了的

5.如果一個辦法不行,趕快換下一個


注:相關教程知識閱讀請移步到建站經驗頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
色综合视频一区中文字幕| 18一19gay欧美视频网站| 在线看日韩av| 91chinesevideo永久地址| 午夜精品一区二区三区av| 高清一区二区三区日本久| 秋霞成人午夜鲁丝一区二区三区| 欧美成在线观看| 国产精品视频一| 中文字幕亚洲综合久久筱田步美| 亚洲天天在线日亚洲洲精| 欧美资源在线观看| 91豆花精品一区| 日韩视频免费中文字幕| 欧美在线www| 91精品国产免费久久久久久| 国产精品福利在线观看| 久久久中文字幕| 欧美综合一区第一页| 亚洲精品国产成人| 亚洲国产天堂久久国产91| 久久视频在线视频| 精品国产欧美一区二区三区成人| 亚洲自拍偷拍区| 欧美黄色小视频| 欧美日韩免费一区| 欧美日本亚洲视频| 色偷偷av一区二区三区| 91精品久久久久久综合乱菊| 久久久久久中文| 久久精视频免费在线久久完整在线看| 欧美麻豆久久久久久中文| 日韩中文在线中文网在线观看| 日韩精品中文字幕久久臀| 一区二区中文字幕| 国产精品直播网红| 欧美国产精品人人做人人爱| 中文字幕久热精品在线视频| 96pao国产成视频永久免费| 在线精品高清中文字幕| 欧美极品第一页| 91精品免费视频| 欧美国产日韩精品| 日本久久精品视频| 日韩av手机在线观看| 亚洲男人天堂九九视频| 粉嫩老牛aⅴ一区二区三区| 日韩美女在线播放| 中文字幕免费国产精品| 国产在线不卡精品| 国产精品国产自产拍高清av水多| 精品少妇一区二区30p| 欧美自拍大量在线观看| 国产精品一区二区久久国产| 海角国产乱辈乱精品视频| 国产精品精品视频一区二区三区| 96精品视频在线| 亚洲色图在线观看| 亚洲国产成人精品久久久国产成人一区| 一本色道久久88亚洲综合88| 成人免费观看49www在线观看| 亚洲天堂免费在线| 亚洲精品成人免费| 这里只有精品视频在线| 黑人巨大精品欧美一区二区一视频| 国产精品18久久久久久麻辣| 欧美肥老太性生活视频| 亚洲国产成人91精品| 国产精品麻豆va在线播放| 日韩在线观看免费全| 欧美高清自拍一区| 国产99久久精品一区二区永久免费| 亚洲一区二区在线| 性欧美长视频免费观看不卡| 播播国产欧美激情| 日本sm极度另类视频| 色老头一区二区三区在线观看| 久久久视频在线| 一区二区三区久久精品| 亚洲精品天天看| 疯狂欧美牲乱大交777| 亚洲欧美在线磁力| 欧美一级电影免费在线观看| 欧美主播福利视频| 国产日韩精品在线| 中文字幕在线看视频国产欧美在线看完整| 亚洲欧美中文日韩v在线观看| 久久视频国产精品免费视频在线| 日韩电影在线观看永久视频免费网站| 国产婷婷97碰碰久久人人蜜臀| 精品久久香蕉国产线看观看亚洲| 国产精品嫩草影院一区二区| 欧美一级淫片aaaaaaa视频| 日韩成人在线播放| 国产精品久久久久秋霞鲁丝| 国产精品男女猛烈高潮激情| 国产一区二区丝袜高跟鞋图片| 国产99久久久欧美黑人| 久久久久久欧美| 97视频在线播放| 中文字幕日韩精品有码视频| 国产成人综合久久| 91精品国产综合久久香蕉的用户体验| 亚洲电影免费观看| 亚洲图中文字幕| 92福利视频午夜1000合集在线观看| 成人97在线观看视频| 亚洲第一页中文字幕| 午夜免费久久久久| 午夜精品理论片| 精品爽片免费看久久| 色av中文字幕一区| 韩国19禁主播vip福利视频| 国产精品永久免费| 成人av番号网| 色偷偷av亚洲男人的天堂| 亚洲国产精品va在线看黑人动漫| 热re91久久精品国99热蜜臀| 中文字幕视频在线免费欧美日韩综合在线看| 91超碰caoporn97人人| 亚洲女人天堂色在线7777| 日本一区二区在线免费播放| 91精品国产免费久久久久久| 92国产精品视频| 国产一区二区精品丝袜| 欧美激情综合色| 美女福利视频一区| 91精品在线观| 国产一区二区三区视频免费| 一区二区三区天堂av| 久久精品国产亚洲7777| 国产精品欧美久久久| 欧美激情亚洲国产| 亚洲欧美成人一区二区在线电影| 国产精品视频白浆免费视频| 欧美日韩中文字幕日韩欧美| 8x海外华人永久免费日韩内陆视频| 91av在线播放| 亚洲免费成人av电影| 日韩电影中文字幕一区| 色噜噜国产精品视频一区二区| 久久久久久久一区二区三区| 亚洲小视频在线观看| 欧美极度另类性三渗透| 亚洲国产第一页| 欧美理论电影网| 国产日韩精品入口| 亚洲白虎美女被爆操| 91精品视频免费看| 久久亚洲欧美日韩精品专区| 亚洲电影免费观看高清| 国产原创欧美精品| 成人精品久久av网站| 国产在线视频91| 成人福利视频在线观看| 欧美视频在线观看 亚洲欧| 欧美日韩第一视频| 国产香蕉精品视频一区二区三区| 日本不卡视频在线播放| 91久久精品国产91久久性色| 自拍偷拍亚洲区| 日韩欧美中文字幕在线观看| 亚洲精品videossex少妇| 欧美整片在线观看|