一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

關于NoSQL的思考-為什么我們要優化存儲的寫性能?

  在NoSQL的許多產品中,我們通過benchmark可以看到的都是寫性能極度提升,而讀性能并沒有太大的漲幅甚至相對傳統RDBMS還有下降。比如Cassandra,MongoDB這兩個NoSQL的杰出代表。究其原因,我們可能會想到是因為當前UGC模式已經發展到白熱化,用戶產生內容導致讀寫比已經接近或者說小于1:1。

  但是我認為這絕不是個中真實原因。

  1 緩存導致存儲的raw read效率不再重要

  真實原因是我們對讀的優化已經做得足夠多了,數據存儲我們使用Memcached,TokyoTyrant/TokyoCabiNET等緩存存儲,頁面及文件緩存我們使用squid,nginx proxy_cache等存儲,都可以達到非常好的讀緩存效果,如果數據即時性要求不高,或者說緩存設計合理(讀寫皆緩存),緩存命中率會足夠的高,因此我們無需再過分優化底層存儲的raw read效率。

  試想緩存層如果有高達99%以上的命中率,那么相對于raw read設備,我們的億級的數據讀取請求就輕松的變成百萬級請求,上千并發輕松變成數十并發。當然,這需要我們的緩存層足夠靠譜。比如nginx proxy_cache 可以多較多,這時候宕掉一臺不至于使全部讀請求穿透到底層存儲。至于多了之后purge等操作如何全面的執行,不在本文討論之列。

  綜上,raw read效率不需要再提升,因為其需求已經被緩存層大量取代。

  2 無法取代的raw write功能

  看到緩存減輕raw read的工作量,我們可以在想是否有方法可以減輕raw write的工作量。答案是不可以的。如果您認為可以。可以留言探討。既然raw write的工作量是不可取代的,那么我們大概可以有兩種方法提升寫操作的性能。

  3.1 sharding

  通過對數據的分區,我們可以將數據進行分布式的存儲,于是每個結點只會分配到一部分的raw write請求。這樣相當于公司員工效率不變,多招了人。但由于結點的增多,其中有結點出問題的效率也大大增加。于是我們不得不做一些replication操作來提供HA方案。

  3.2 提升raw write效率

  如上面的舉例,我們只能選擇提升raw write效率來實現總體(包括cache層)更好的讀寫效率。這里通常使用的方法就是將隨機的寫操作在內存中進行序列化,并在一定量后進行順序的flush到磁盤操作。所謂將內存當成硬盤,將硬盤當作磁帶就是這個意思。(可參見我更早的一篇文章:《NoSQL理論之-內存是新的硬盤,硬盤是新的磁帶》)所以我們看到前面說到的很多NoSQL產品著重對寫操作進行了優化,而對讀性能提升并不明顯,甚至不惜以更慢的讀作為提升寫操作性能的代價。

  4 總結

  由于讀性能可以通過設置合理的緩存策略來減少raw read操作的數量。因此不僅對讀寫比不大的情形需要著重進行寫操作的優化,對讀寫比大的情況下,仍舊需要優化寫性能而非讀性能。

it知識庫關于NoSQL的思考-為什么我們要優化存儲的寫性能?,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 国产免费一区二区三区最新 | 久久国产乱子伦精品免费不卡 | 欧美人与z0z0xxxx | 欧美性色视频 | 狠狠色狠狠色很很综合很久久 | 国产一区二区高清视频 | 色综合网站在线 | 欧美 亚洲 丝袜 清纯 中文 | 日本三级韩国三级美三级91 | 91精品啪在线观看国产 | 国产精品自在自线亚洲 | 欧美日韩亚洲另类人人澡 | 男人女人做刺激视频免费 | 欧美xxxx色视频在线观看免费 | 欧美日韩国产另类一区二区三区 | 午夜免费的国产片在线观看 | 91精品视频网站 | 欧美性生活网站 | 站长推荐国产精品视频 | 天天干天天干天天 | 精品视频免费在线观看 | 高清一区二区在线观看 | 91在线亚洲 | 日本韩国三级在线 | 色吧亚洲欧美另类 | 加勒比在线 | 成人免费在线观看视频 | 久久久久久九九 | 亚洲精品图区 | 久久久综合网 | 在线a网站 | 欧美激情成人网 | 偷偷狠狠的日日2020 | 国产乱子精品免费视观看片 | 精品福利视频一区二区三区 | 久久一日本道色综合久久m 久久伊人草 | 性感美女毛片 | 欧美一级精品 | 草草线在成年免费视频网站 | 国产小视频在线 | 日韩中文字幕精品一区在线 |