<output id="qn6qe"></output>

    1. <output id="qn6qe"><tt id="qn6qe"></tt></output>
    2. <strike id="qn6qe"></strike>

      亚洲 日本 欧洲 欧美 视频,日韩中文字幕有码av,一本一道av中文字幕无码,国产线播放免费人成视频播放,人妻少妇偷人无码视频,日夜啪啪一区二区三区,国产尤物精品自在拍视频首页,久热这里只有精品12

      [轉]節約內存:Instagram的Redis實踐

      Instagram可以說是網拍App的始祖級應用,也是當前最火熱的拍照App之一,Instagram的照片數量已經達到3億,而在Instagram里,我們需要知道每一張照片的作者是誰,下面就是Instagram團隊如何使用Redis來解決這個問題并進行內存優化的。

      首先,這個通過圖片ID反查用戶UID的應用有以下幾點需求:

      • 查詢速度要足夠快
      • 數據要能全部放到內存里,最好是一臺EC2的 high-memory 機型就能存儲(17GB或者34GB的,68GB的太浪費了)
      • 要合適Instagram現有的架構(Instagram對Redis有一定的使用經驗,比如這個應用
      • 支持持久化,這樣在服務器重啟后不需要再預熱

      Instagram的開發者首先否定了數據庫存儲的方案,他們保持了KISS原則(Keep It Simple and Stupid),因為這個應用根本用不到數據庫的update功能,事務功能和關聯查詢等等牛X功能,所以不必為這些用不到的功能去選擇維護一個數據庫。

      于是他們選擇了Redis,Redis是一個支持持久化的內存數據庫,所有的數據都被存儲在內存中(忘掉VM吧),而最簡單的實現就是使用Redis的String結構來做一個key-value存儲就行了。像這樣:

      SET media:1155315 939
      GET media:1155315
      > 939

      其中1155315是圖片ID,939是用戶ID,我們將每一張圖片ID為作key,用戶uid作為value來存成key-value對。然后他們進行了測試,將數據按上面的方法存儲,1,000,000數據會用掉70MB內存,300,000,000張照片就會用掉21GB的內存。對比預算的17GB還是超支了。

      (NoSQLFan:其實這里我們可以看到一個優化點,我們可以將key值前面相同的media去掉,只存數字,這樣key的長度就減少了,減少key值對內存的開銷【注:Redis的key值不會做字符串到數字的轉換,所以這里節省的,僅僅是media:這6個字節的開銷】。經過實驗,內存占用會降到50MB,總的內存占用是15GB,是滿足需求的,但是Instagram后面的改進任然有必要)

      于是Instagram的開發者向Redis的開發者之一Pieter Noordhuis詢問優化方案,得到的回復是使用Hash結構。具體的做法就是將數據分段,每一段使用一個Hash結構存儲,由于Hash結構會在單個Hash元素在不足一定數量時進行壓縮存儲,所以可以大量節約內存。這一點在上面的String結構里是不存在的。而這個一定數量是由配置文件中的hash-zipmap-max-entries參數來控制的。經過開發者們的實驗,將hash-zipmap-max-entries設置為1000時,性能比較好,超過1000后HSET命令就會導致CPU消耗變得非常大。

      于是他們改變了方案,將數據存成如下結構:

      HSET "mediabucket:1155" "1155315" "939"
      HGET "mediabucket:1155" "1155315"
      > "939"

      通過取7位的圖片ID的前四位為Hash結構的key值,保證了每個Hash內部只包含3位的key,也就是1000個。

      再做一次實驗,結果是每1,000,000個key只消耗了16MB的內存。總內存使用也降到了5GB,滿足了應用需求。

      (NoSQLFan:同樣的,這里我們還是可以再進行優化,首先是將Hash結構的key值變成純數字,這樣key長度減少了12個字節,其次是將Hash結構中的subkey值變成三位數,這又減少了4個字節的開銷,如下所示。經過實驗,內存占用量會降到10MB,總內存占用為3GB)

      HSET "1155" "315" "939"
      HGET "1155" "315"
      > "939"

      優化無止境,只要肯琢磨。希望你在使用存儲產品時也能如此愛惜內存。

       

      來源:instagram-engineering.tumblr.com

      posted @ 2013-02-01 11:29  killkill  閱讀(1187)  評論(0)    收藏  舉報
      主站蜘蛛池模板: 国产成人午夜福利在线观看| 国产午夜福利不卡在线观看| 国产女同一区二区在线| 亚洲欧美卡通另类丝袜美腿| 精品人妻大屁股白浆无码| 熟女一区二区中文在线| 少妇爽到呻吟的视频| 99久久激情国产精品| 免费现黄频在线观看国产| 日韩有码中文字幕国产| 毛茸茸性xxxx毛茸茸毛茸茸| 亚洲国产av久久久| 内射中出无码护士在线| 亚洲国产初高中生女av| 亚洲综合精品第一页| 国产中文字幕久久黄色片| 无遮高潮国产免费观看| 国产精品视频不卡一区二区| 国产一区二区亚洲精品| 国产情侣激情在线对白| 少妇xxxxx性开放| 四房播色综合久久婷婷| 国产精品乱人伦一区二区| 好吊视频一区二区三区人妖| 成人午夜视频一区二区无码| 中文字幕人妻色偷偷久久| 日本一区二区三区在线播放| 免费看黄色亚洲一区久久| 欧美乱妇高清无乱码免费| 国产精品无码av天天爽播放器 | 四虎永久在线精品无码视频| 国产乱码精品一区二区麻豆| 中国老熟妇自拍hd发布| 国产福利微视频一区二区| 宝贝腿开大点我添添公口述视频| 性欧美老人牲交xxxxx视频| 啊轻点灬大JI巴太粗太长了在线| 亚洲码与欧洲码区别入口| 亚洲av综合av一区| 亚洲少妇一区二区三区老| 一本av高清一区二区三区|