選擇KV數據庫最重要的是什麼

本文分享自華爲雲社區《選擇KV數據庫最重要的是什麼?》,作者:GaussDB 數據庫 。

經常有客戶提到KV數據庫,但卻偏偏“不要Redis”。比如有個做安全威脅分析平臺的客戶,他們明確表示自己對可靠性要求非常高,需要的不是開源Redis這種內存緩存庫,而是KV數據庫。

雖然最後我也沒問清楚他們業務存啥(推測是這塊業務數據比較機密),但確實業務本身對可靠性要求非常高,開源Redis自身的可靠性無法滿足他們的要求,最終該用戶選擇使用GaussDB(for Redis)數據庫,當前數據量已經是2TB規模,一直穩定運行中。

真正的KV數據庫,業界有好幾項開源的項目,雲廠商也紛紛推出自家產品,比如華爲雲GaussDB(for Redis)。使用方在調研選型KV數據庫的時候,由於要存儲百GB甚至數十TB級的重要數據,首先關注的是數據庫是否穩定可靠,同時懂行的客戶一般也會聊到自建開源Redis的“不靠譜”問題,例如:

問題1:自建開源Redis有丟數據和數據不一致的風險

廣告競價和推薦等大數據業務將海量數據存放在KV數據庫,開源Redis是將全量數據存在內存中,雖然有RDB和AOF的備份機制,但那只是普通的文本文件,可靠性很低,只能作爲兜底手段,關鍵數據該丟還是會丟。

另外,開源Redis主備節點採用異步複製的機制,故障倒換的時候有可能出現明顯的數據不一致,像是分佈式鎖這類場景就會很尷尬:

圖片

問題2:“Cache+DB”的業務架構複雜

電商和遊戲等互聯網業務採用Redis緩存+持久化數據庫的架構,通過緩存加速來提升業務的使用體驗,業務需要設計緩存的淘汰機制,還需要解決緩存與持久化數據庫之間的數據一致性問題,業務架構複雜。

問題3:開源Redis分片故障不能提供服務,故障場景對業務影響比較大

金融、財經和電商等業務對可靠性要求極高,開源Redis單個數據分片存放在主備兩個節點上,如果兩個節點都出現故障,則整個分片的數據不可訪問,應對極端故障場景的能力不足。

社區開源的項目一般都引入了RocksDB存儲引擎(這東西深的很),其實能把上層KV業務變得穩定許多,通過持久化存儲介質替代內存的方式來彌補開源Redis的不足。但它們無法完美解決性能、兼容性和擴容的問題,更無法保證數據庫的穩定可靠,還需要投入專門的人力進行搭建維護、調優等……最終綜合算下來,成本並不低。

雲廠商的KV數據庫由於進行了技術創新與優化,一般比較給力,以GaussDB(for Redis)爲例,下面從以下幾個角度解釋如何把一款產品做到“靠譜”:

企業級特性1:採用內存+NVMe的存儲方案,全量數據三副本持久化存儲

GaussDB(for Redis)在存儲池中有三副本落盤到NVMe存儲池中,宕機不會丟數據,也不會存在主從同步的問題。因此,客戶可以直接拿GaussDB(for Redis)當做持久化數據庫使用,一庫頂多庫,業務架構變得簡單,也減輕了多套數據庫的運維成本。

圖片

企業級特性2:採用存算分離的架構,支持3AZ部署和N-1故障的超高可用

GaussDB(for Redis)支持3AZ部署計算節點,均勻分佈在3個不同的可用區,如果遇到1個或2個可用區出現網絡、製冷、電力等突發故障,剩餘可用區的節點能接管故障節點的數據分片,還能繼續支撐業務訪問全量數據。

同樣得益於存算分離的架構,GaussDB(for Redis)將全量數據落盤到分佈式存儲池,最多支撐N-1故障,哪怕只剩下一個節點正常,也能通過接管所有分片,繼續支撐業務運行。

圖片

企業級特性3:雙活解決方案支持極致穩定可靠,靈活組網

如果遇到大規模網絡故障、電力故障、火災或自然災害,導致整個數據庫實例不可用,甚至整個Region都不可用,GaussDB(for Redis)也在這些極端場景下保證業務的連續性。

GaussDB(for Redis)支持給兩個跨region的實例建立雙活關係,支持數據的同步,如果其中一個實例故障,另一個實例能接管業務,持續提供可靠的數據庫服務。雙活解決方案已在華爲內部ERP中穩定部署運行,爲ERP業務的持續運行提供強有力的保障。

圖片

總結

綜上所述,GaussDB(for Redis)提供了全量數據三副本持久化存儲,支持3AZ部署和N-1故障的超高可用,雙活解決方案支持極致穩定可靠,靈活組網,穩定性和可靠性遠超開源Redis,是一款真正能讓企業核心業務放心上雲的KV數據庫。

所以,如果你的業務需要一款穩定可靠的KV數據庫,可以試試GaussDB(for Redis)。

點擊關注,第一時間瞭解華爲雲新鮮技術~

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章