日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

节约内存:Instagram的Redis实践(转)

發布時間:2023/12/10 数据库 47 豆豆
生活随笔 收集整理的這篇文章主要介紹了 节约内存:Instagram的Redis实践(转) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

一、問題:

數據庫表數據量極大(千萬條),要求讓服務器更加快速地響應用戶的需求。 二、解決方案: 1.通過高速服務器Cache緩存數據庫數據 2.內存數據庫 三、主流解Cache和數據庫對比從以上各數據可知,對于我們產品最可行的技術方案有兩種: 1.Memcached?? ? ? ? 內存Key-Value Cache 2.Redis?? ? ? ? ? ? ? ? ? ? 內存數據庫

四,節約內存: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"

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

參考:

  • http://blog.nosqlfan.com/html/3379.html
  • http://instagram-engineering.tumblr.com/post/12202313862/storing-hundreds-of-millions-of-simple-key-value
  • http://www.open-open.com/lib/view/open1409643182369.html

轉載于:https://www.cnblogs.com/JoannaQ/p/4470272.html

總結

以上是生活随笔為你收集整理的节约内存:Instagram的Redis实践(转)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 欧美成人精品一区二区三区在线观看 | 黄一区二区三区 | 国产黄a三级三级三级看三级男男 | 天天躁日日躁aaaxxⅹ | 双腿张开被9个男人调教 | 欧美一区二区三区日韩 | 久久久99精品国产一区二区三区 | 不卡视频一区二区三区 | 伊人网色 | 成年人高清视频 | sese亚洲 | 日本成人免费网站 | 91嫩草视频在线观看 | 丝袜视频在线 | 国产sm主人调教女m视频 | 在线观看国产一区二区 | 国产欧美一区二区三区鸳鸯浴 | 91极品蜜桃臀 | 色多多网站 | 免费a级| 中文字幕一区二区三区四区视频 | 亚洲九九九九 | 国产馆视频 | 91操人 | 中国精品久久 | 亚洲一区二区三区电影 | 久久九九精品 | 精品处破女学生 | 亚洲无限看 | 国产精品亚州 | 91免费福利| 8x8ⅹ国产精品一区二区 | 免费看日韩av | 99re6这里有精品热视频 | 久久综合精品国产二区无码不卡 | 欧美岛国国产 | 秋霞在线视频观看 | 美女av影院| 欧美不卡在线观看 | 性欧美18一19性猛交 | 精品午夜一区二区三区 | 视频在线一区二区 | 骚虎免费视频 | 经典三级av在线 | 欧美人妻精品一区二区三区 | 一本色道久久综合熟妇 | 日韩一区二区免费看 | 久久精品无码专区免费 | 国产手机av在线 | 天堂中文在线最新 | 亚洲精品乱码久久久久久写真 | 波多野在线观看 | 日韩一区免费观看 | 国产一级片久久 | 婷婷久久亚洲 | 中国av片| 九一成人网 | 97av在线 | 激情文学亚洲 | 黄色网址你懂得 | 国产熟女一区二区三区五月婷 | 白白色视频在线 | 久久影视网 | 91嫩草视频在线观看 | 黄色一级视频免费观看 | 午夜性片 | 亚洲二区在线视频 | 国产精品欧美久久久久天天影视 | 91一区二区在线 | av大片网址 | 天天操天天射天天 | 久久久久久成人 | 欧美日韩在线视频一区 | 欧美 亚洲 另类 激情 另类 | 在线91观看 | 日本一级三级三级三级 | 九九热精品视频在线观看 | 国产成人主播 | 五月婷婷六月综合 | 天堂综合网久久 | 国内成人精品视频 | 国产一区二区免费在线 | 久久久久网站 | 邵氏电影《金莲外传2》免费观看 | 亚洲午夜精品一区 | 欧美久久激情 | 91综合国产| 欧美毛片在线观看 | 在线观看aaa | 日韩一区二区三区网站 | 九九热久久免费视频 | 日本欧美不卡 | www.久久久久久久久 | 国产精品久久久久久人妻精品动漫 | 91成人网页 | 伊人99re | 爱爱免费网站 | 国产手机看片 | 国产精品一区2区 |