中文字幕日韩一区二区_国产一区二区av_国产毛片av_久久久久国产一区_色婷婷电影_国产一区二区精品

關于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的思考-為什么我們要優化存儲的寫性能?,轉載需保留來源!

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

主站蜘蛛池模板: 精品国产91| 日本色高清| 国产亚洲人成a在线v网站 | 一区二区三区四区不卡视频 | 久久久综合精品 | 老司机67194精品线观看 | av夜夜操| www.久久| 国产精品久久久久久久久图文区 | 在线看免费的a | 99热热| 毛片一区二区 | 日韩综合在线 | 在线观看亚洲精品视频 | 91久久国产综合久久91精品网站 | 4h影视 | 天天干夜夜操 | www四虎影视| 国产精品高潮呻吟久久久久 | 日韩久久久久 | 一a一片一级一片啪啪 | 国产精品视频一区二区三区, | 日本在线中文 | 中文字幕一区二区三区在线观看 | 国产一区二区三区四区三区四 | 成人日批视频 | 成人免费视频网站在线观看 | 精品国产亚洲一区二区三区大结局 | 中文成人在线 | 精品国产一级 | 高清视频一区二区三区 | 瑞克和莫蒂第五季在线观看 | 亚洲成人99 | 国产精品一区二 | 毛片a级| 四虎影院在线观看免费视频 | 成人免费视频网站在线看 | 性做久久久久久免费观看欧美 | 99久久免费精品国产男女高不卡 | 久久久久久亚洲精品 | 成人免费毛片在线观看 |