GeminiDB PITR,讓游戲回檔“進退自如”!

来源:https://www.cnblogs.com/huaweiyun/p/18209868
-Advertisement-
Play Games

GeminiDB PITR執行數據快照業務無感,通常可在5分鐘以內恢復到指定時間點,有效解決傳統備份方案時間長、恢復粒度大等痛點問題。 ...


本文分享自華為雲社區《GeminiDB PITR,讓游戲回檔“進退自如”!》,作者:GaussDB 資料庫。

在實際業務場景中,客戶資料庫難免會出現數據損毀、數據丟失、數據誤刪除等故障場景。為保障業務的正常運行,通常需要將資料庫恢復到故障發生前的某一個正常時刻。傳統資料庫採取周期性備份策略,即在系統故障時對數據進行恢復。因其數據恢復耗時較長,可恢復時間顆粒度較大,導致客戶業務受損嚴重。

什麼是PITR呢?

PITR(Point-in-Time Recovery),是指資料庫的“時間點恢復”功能。它是一種資料庫恢復技術,通常用於恢復誤刪除的數據或者誤操作導致損壞的數據,將其恢復到一個指定時間點的數據狀態。

以游戲場景為例,在游戲運行期間,有玩家利用游戲漏洞非法複製裝備、貨幣,使游戲公平性遭到破壞。傳統資料庫備份頻率一般是一天全備一次,備份間隔即一整天,不僅恢復時間長、時間粒度大,甚至無法恢復到想要時間點等。而GeminiDB Redis介面新增的PITR特性能夠讓游戲數據快速回檔,可根據客戶自定的備份粒度,最低支持5分鐘粒度,自行選擇需要恢復的時間點,實現數據的快速恢復。

1.png

PITR功能優勢

1. 備份任務無感,業務更穩健

GeminiDB Redis介面的PITR功能不涉及數據的拷貝,備份任務業務無感知,不影響數據訪問,讓客戶業務更加穩健。

GeminiDB Redis介面快照原理是通過記錄文件系統的狀態來實現的,而不是通過複製文件本身來實現的,是瞬時生成的;快照存儲當前時刻的底層數據的元數據信息,比如數據塊信息、定址信息等,形成快照。因此,當打高速數據快照時,業務可以繼續運行,而不會受到任何影響。

在實際測試中,基於客戶業務6w的併發數據量對資料庫進行訪問,開啟GeminiDB Redis介面PITR功能,以最小粒度5分鐘執行一次快照。

下麵是4個時間點每隔5分鐘執行一次快照結果(以下為UTC時間,監控時間+8):

2.png

觀察可知,QPS,CPU,記憶體,P99時延均無波動,對客戶業務無影響。

3.png

2. 支持分鐘級快速恢復,恢復時長與數據大小無關

PITR數據快照文件可以在本地保存,不用上傳到冷存儲介質,因此,不涉及數據的拷貝搬遷,還可支持隨時數據恢復。

PITR恢復,數據恢復時長與數據大小無關,能快速恢複數百GB數據,通常可在5分鐘以內恢複數據,保證客戶業務可靠性。除此以外,PITR還可多次前後恢復,恢復到指定時間點後,既可向前,也可向後,讓客戶使用更省心。

我們分別測試了8U3節點實例,數據100GB和200GB的回檔速度。

4.png

3. 比開源Redis數據備份性能更優

開源Redis使用多進程寫時複製機制來實現快照的持久化。在持久化過程中,調用fork()產生一個子進程,fork()會阻塞Redis長達數百毫秒,對業務產生抖動;fork()的寫時複製技術(COW)會造成記憶體過度使用。如果fork()期間產生大量的寫操作,會導致記憶體嚴重浪費甚至OOM,通常記憶體利用率不足50%。而GeminiDB Redis介面的PITR特性不涉及數據的拷貝搬遷,因此,對業務基本無影響,且具有快照速度快,數據穩定,安全等特點。

PITR功能使用方法

1. 如何開啟GeminiDB Redis介面 PITR功能?

在控制台,實例詳情頁->備份恢復->設置恢復到指定時間點策略,即可打開。備份時間間隔最低支持5分鐘,最高支持120分鐘,保留天數最大支持7天。

5.png

2. 如何恢復到執行的時間點?

實例詳情頁->備份恢復->恢復到指定時間點,便可本實例快速恢復到指定時間點。

6.jpg

總結

GeminiDB PITR執行數據快照業務無感,通常可在5分鐘以內恢復到指定時間點,尤其是在業務異常場景可快速回退,降低損失,有效解決傳統備份方案時間長、恢復粒度大等痛點問題。因此,GeminiDB在游戲、金融等行業有著廣泛應用。

未來,GeminiDB Redis介面會進一步支持並完善數據恢復至某個秒級的時間點功能。也將持續致力於開發更多好用的企業級特性,幫助客戶輕鬆運維,高效開發。我們期待與全球的企業和開發者合作,共同探索數據的未來,推動技術和業務的發展。

 

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

 


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

-Advertisement-
Play Games
更多相關文章
  • 前言 插件化的需求主要源於對軟體架構靈活性的追求,特別是在開發大型、複雜或需要不斷更新的軟體系統時,插件化可以提高軟體系統的可擴展性、可定製性、隔離性、安全性、可維護性、模塊化、易於升級和更新以及支持第三方開發等方面的能力,從而滿足不斷變化的業務需求和技術挑戰。 一、插件化探索 在WPF中我們想要開 ...
  • tc(Traffic Control)是 Linux 中用於流量控制和網路模擬的強大工具。你可以使用它來模擬網路延遲、帶寬限制、數據包丟失等。 以下是一個使用 tc 模擬網路延遲的基本步驟: 1.查看當前的 qdisc(隊列規則)和 filter(過濾器) 首先,確保你的網路介面沒有設置任何 qdi ...
  • 一:Pod介紹 pod資源的各種配置和原理 關於很多yaml文件的編寫,都是基於配置引出來的 1:pod的結構和定義 每個Pod中都可以包含一個或者多個容器,這些容器可以分為2大類: 1:用戶所在的容器,數量可多可少(用戶容器) 2:pause容器,這是每個pod都會有的一個跟容器,作用有2個 1、 ...
  • 記錄一下 今天突然發現之前的小米妙享用不了 百度了一下才知道澎湃上線後 這玩意兒好像就沒用了; 所以找了一圈替代品,發現了小米電腦管家這個東西內置了HyperConnect跨端智聯,但是這玩意兒又不能直接安裝,又找了一圈怎麼安裝; 原文鏈接:非小米電腦安裝小米電腦管家-雪餅 (xue6ing.cn) ...
  • FAT32是從FAT12、FAT16發展而來,目前主要應用在移動存儲設備中,比如SD卡、TF卡。隱藏的FAT文件系統現在也有被大量使用在UEFI啟動分區中。 為使文章簡單易讀,下麵內容特意隱藏了很多實現細節,關於分區、格式化等相關的內容,可以查看之前的文章: 文件系統(一):存儲介質、原理與架構 文 ...
  • 一、邏輯地址和物理地址 1.1 含義:邏輯地址和物理地址是電腦記憶體管理中的兩個核心概念,它們在電腦系統中扮演著不同的角色。 邏輯地址(Logical Address),也稱為虛擬地址(Virtual Address),是由操作系統提供給程式使用的地址。這些地址是在程式中使用的,但並不是實際存在的 ...
  • 文章參考:https://gitee.com/socbis/linux-lvgl lvgl on linux Frame buffer 主機環境: Ubuntu 18.04 lvgl 8.0.1 獲取源碼並運行demo 獲取源碼 需要3樣東西來構建demo : lvgl核心控制項庫: 從此處獲取源碼 ...
  • 大家好,我是 Java陳序員。 今天,給大家分享下在 Linux 環境中如何安裝卸載 MySQL. 關註微信公眾號:【Java陳序員】,獲取開源項目分享、AI副業分享、超200本經典電腦電子書籍等。 MySQL 安裝 準備一臺 Linux 伺服器 下載 Linux 版 MySQL 安裝包 下載地址 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...