選擇KV資料庫最重要的是什麼

来源:https://www.cnblogs.com/huaweiyun/archive/2023/03/24/17251824.html
-Advertisement-
Play Games

本文分享自華為雲社區《選擇KV資料庫最重要的是什麼?》,作者:GaussDB 資料庫 。 經常有客戶提到KV資料庫,但卻偏偏“不要Redis”。比如有個做安全威脅分析平臺的客戶,他們明確表示自己對可靠性要求非常高,需要的不是開源Redis這種記憶體緩存庫,而是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)。

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


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • .net core 自定義授權策略提供程式進行許可權驗證 在這之前先瞭解一下鑒權和授權的概念; 鑒權 鑒權可以說是身份驗證,身份驗證是確定用戶身份的過程; 在ASP.NET Core 中身份驗證是由身份驗證服務IAuthenticationService負責的,它被身份驗證中間件使用, 身份驗證服務會 ...
  • 上一篇 ASP.NET Core - 選項系統之選項配置 中提到 IOptions、IOptionsMonitor 和 IOptionsSnapshot 三個介面,通過這三個介面都可以從依賴註入容器中解析出已經配置的選項類,在我們通過 Configure 方法配置選項時,這三個介面會被同時註冊,但三 ...
  • 1. 應用程式級別代碼壞味道 1.1. 布爾盲點 1.1.1. 由於函數使用布爾值而導致的信息缺失 1.1.2. 解決方案是將布爾替換為枚舉類型 1.2. 組合爆炸 1.2.1. 不同的代碼使用不同的參數組合來執行同一件事情的產物 1.2.2. 解決方案使用泛型 1.3. 人為複雜性 1.3.1.  ...
  • 1 降壓 電容有容抗,可以承擔分壓的作用。容抗計算如下 Xc=1/(2πfc) 其中 f 為電流頻率 ,c 為電容大小。 計算電容分壓時不要忘記電容電壓相位差與電阻等普通元件相差π/2。 例如下圖,若要電容分壓210v,則需要電容分擔電壓大小為Vc=(220^2-10^2)^0.5=219.77v, ...
  • 本系列旨在交流 ESP32-S3 硬體開發環境的搭建,通過一些基本的示例來展示怎麼用 ESP-IDF (Espressif IoT Development Framework) 來安裝、配置環境,並編譯、下載固件至 BPI-Leaf-S3 開發板等步驟。如果有什麼沒提到或者有問題的,歡迎各位留言交流... ...
  • 存儲過程 特定功能的的SQL指令 進行封裝 編譯之後存儲在資料庫伺服器中客戶端通過名字調用這個SQL指令集 優點: 防止SQL 在網路中惡意修改 無需客戶端編寫 通過網路傳送 存儲過程 SQL存在邏輯關係 支持流程式控制制 分支 迴圈 ##基本語法 創建存儲過程 輸入參數 a 輸入參數b 都是 int ...
  • windows安裝redis及配置教程,附網盤資源 鏈接:https://pan.baidu.com/s/1KvcyY27_q7aI2hQ7QRsEGA?pwd=iidx 一、windows系統安裝及配置 解壓文件,準備開始配置、安裝服務。 1.1、註冊redis的windows服務 在該文件夾中打 ...
  • windows安裝mysql8免安裝版教程,附網盤資源 鏈接:https://pan.baidu.com/s/1_qagfA-i7CbeWG3urIAlgw?pwd=iidx 提取碼:iidx 一、前言 本次使用的mysql版本為mysql8.0.32,安裝的系統為windows系統。使用免安裝的方 ...
一周排行
    -Advertisement-
    Play Games
  • 最近做項目過程中,使用到了海康相機,官方只提供了C/C++的SDK,沒有搜尋到一個合適的封裝了的C#庫,故自己動手,簡單的封裝了一下,方便大家也方便自己使用和二次開發 ...
  • 前言 MediatR 是 .NET 下的一個實現消息傳遞的庫,輕量級、簡潔高效,用於實現進程內的消息傳遞機制。它基於中介者設計模式,支持請求/響應、命令、查詢、通知和事件等多種消息傳遞模式。通過泛型支持,MediatR 可以智能地調度不同類型的消息,非常適合用於領域事件處理。 在本文中,將通過一個簡 ...
  • 前言 今天給大家推薦一個超實用的開源項目《.NET 7 + Vue 許可權管理系統 小白快速上手》,DncZeus的願景就是做一個.NET 領域小白也能上手的簡易、通用的後臺許可權管理模板系統基礎框架。 不管你是技術小白還是技術大佬或者是不懂前端Vue 的新手,這個項目可以快速上手讓我們從0到1,搭建自 ...
  • 第1章:WPF概述 本章目標 瞭解Windows圖形演化 瞭解WPF高級API 瞭解解析度無關性概念 瞭解WPF體繫結構 瞭解WPF 4.5 WPF概述 ​ 歡迎使用 Windows Presentation Foundation (WPF) 桌面指南,這是一個與解析度無關的 UI 框架,使用基於矢 ...
  • 在日常開發中,並不是所有的功能都是用戶可見的,還在一些背後默默支持的程式,這些程式通常以服務的形式出現,統稱為輔助角色服務。今天以一個簡單的小例子,簡述基於.NET開發輔助角色服務的相關內容,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 第3章:佈局 本章目標 理解佈局的原則 理解佈局的過程 理解佈局的容器 掌握各類佈局容器的運用 理解 WPF 中的佈局 WPF 佈局原則 ​ WPF 視窗只能包含單個元素。為在WPF 視窗中放置多個元素並創建更貼近實用的用戶男面,需要在視窗上放置一個容器,然後在這個容器中添加其他元素。造成這一限制的 ...
  • 前言 在平時項目開發中,定時任務調度是一項重要的功能,廣泛應用於後臺作業、計劃任務和自動化腳本等模塊。 FreeScheduler 是一款輕量級且功能強大的定時任務調度庫,它支持臨時的延時任務和重覆迴圈任務(可持久化),能夠按秒、每天/每周/每月固定時間或自定義間隔執行(CRON 表達式)。 此外 ...
  • 目錄Blazor 組件基礎路由導航參數組件參數路由參數生命周期事件狀態更改組件事件 Blazor 組件 基礎 新建一個項目命名為 MyComponents ,項目模板的交互類型選 Auto ,其它保持預設選項: 客戶端組件 (Auto/WebAssembly): 最終解決方案裡面會有兩個項目:伺服器 ...
  • 先看一下效果吧: isChecked = false 的時候的效果 isChecked = true 的時候的效果 然後我們來實現一下這個效果吧 第一步:創建一個空的wpf項目; 第二步:在項目裡面添加一個checkbox <Grid> <CheckBox HorizontalAlignment=" ...
  • 在編寫上位機軟體時,需要經常處理命令拼接與其他設備進行通信,通常對不同的命令封裝成不同的方法,擴展稍許麻煩。 本次擬以特性方式實現,以兼顧維護性與擴展性。 思想: 一種命令對應一個類,其類中的各個屬性對應各個命令段,通過特性的方式,實現其在這包數據命令中的位置、大端或小端及其轉換為對應的目標類型; ...