xtrabackup備份mysql資料庫的使用方法

来源:http://www.cnblogs.com/stacks/archive/2017/07/14/7168427.html
-Advertisement-
Play Games

xtrabackup是由percona提供的mysql備份工具,它是一款物理備份工具,通過連接資料庫把資料庫的數據備份出來。對於innodb存儲引擎其支持全量備份和增量備份。對於myisam存儲引擎只支持增量備份。因為xtrabackup對innodb的增量備份是基於表空間的LSN進行的,所謂LSN ...


xtrabackup是由percona提供的mysql備份工具,它是一款物理備份工具,通過連接資料庫把資料庫的數據備份出來。對於innodb存儲引擎其支持全量備份和增量備份。對於myisam存儲引擎只支持增量備份。因為xtrabackup對innodb的增量備份是基於表空間的LSN進行的,所謂LSN即:表空間分成多個數據塊,每個數據塊都有相應的序列號,當數據塊數據發生變化則更新序列號。全量備份即備份所有數據塊,則增量備份則基於全量備份最後一個數據塊的序列號到最新的數據塊序列號進行備份。因為myisam不支持表空間,所以不能進行增量備份。

xtrabackup備份出來的數據包括:

  • 表空間
  • 數據文件
  • 二進位日誌
  • 事務日誌
    ...

xtrabackup在進行數據恢復之前需要註意如下要點:

  1. 如果有增量備份則需要在恢復之前先進行增量備份和全備份的合併再恢復;
  2. 如果是支持事務的表的備份,則恢復之前需要先進行事務日誌的回滾和提交操作;
  3. 如果是多個連續的備份操作,則只需要提交事務日誌,不需要回滾,只有在全部備份操作合成之後再進行事務的回滾;

此文通過詳細的實驗步驟來演示xtrabackup的使用方法。
實驗步驟

  1. 一臺centos7虛擬機,安裝mariadb-5.5.52版本的資料庫,首先通過sql腳本導入hellodb測試庫,其包括一個students數據表,此實驗在students表中進行操作,命令如下:
    mysql -uroot < hellodb.sql
  2. 安裝xtrabackup,可以從官方網站下載安裝包,然後通過yum進行安裝,下載站點為:https://www.percona.com/downloads/XtraBackup/LATEST/,此處不再演示安裝過程
  3. xtrabackup的主要命令為innobackupex,通過innobackupex --help或者man手冊可以獲取到幫助信息;
  4. 資料庫已經導入,此時可以進行資料庫的備份操作,先進行資料庫的全量備份和恢復:
    1. 首先確保資料庫已經開啟二進位日誌,通過show global variables like 'log_bin';命令可以看到是否已經開啟,通過show binary logs;可以看到目前正在使用的二進位日誌是哪一個;
    2. 通過xtrabackup進行備份,數據備份到/data/backup目錄下,備份完成會在指定目錄下生成一個以當前時間命名的文件夾:
      innobackupex -u root /data/backup
    3. 文件夾內容如下:
      • xtrabackup_binlog_info:記錄二進位日誌的內容;
      • xtrabackup_checkpoints:記錄備份類型,開始和結束的lsn編號等備份信息;
      • xtrabackup_info:記錄更詳細的備份信息,如是否為所有庫備份,是否壓縮,備份執行的命令等信息;
      • xtrabackup_logfile:記錄的是事務日誌,為二進位文件,不可查看;
    4. 此時就備份成功了,然後演示資料庫的恢復操作。註意:恢復之前需要首先停止資料庫服務:
      innobackupex --apply-log 2017-07-13_21-02-07/ #首先進行事務日誌的提交和回滾 innobackupex --copy-back 2017-07-13_21-02-07/ #進行數據恢復,會自動把數據恢復到mysql的數據目錄下
    5. 恢覆成功之後所有已經恢複數據的屬主和屬組都是root用戶,需要修改成mysql用戶才能登陸資料庫;
    6. 此時登陸資料庫即可看到所有數據都已經恢復了。
  5. 這次演示增量備份和恢復操作:
    1. 往資料庫中插入幾條新的信息,然後進行資料庫的增量備份;
    2. 通過如下命令進行資料庫的增量備份,備份成功之後還是會在/data/backup目錄下生成一個新的以時間命名的文件夾:
      innobackupex -u root -p 1234567a --incremental --incremental-basedir=/data/backup/2017-07-13_21-07-23/ /data/backup/
    3. 然後停掉資料庫服務,刪除資料庫目錄下的所有數據,進行數據恢復操作,步驟如下:
      innobackupex --apply-log --redo-only 2017-07-13_22-16-19/ #進行全量備份的事務提交,但是不回滾未提交事務,因為未提交事務可能在下次的增量備份中提交 innobackupex --apply-log --redo-only 2017-07-13_22-16-19/ --incremental-dir=2017-07-13_22-18-34/ #進行增量備份和全備份的合成已經事務提交工作 innobackupex --apply-log 2017-07-13_22-16-19/ #對於全備份也沒有完成的事務進行回滾操作 innobackupex --copy-back 2017-07-13_22-16-19/ #此時採用全備份即可恢複數據,不再需要增量備份,因為已經進行了備份的合成操作
    4. 同樣需要修改恢復完成數據的屬主和屬組,然後登陸資料庫即可看到完整是數據,此時實驗演示完成。

      註意:
      • 生產環境建議二進位日誌和數據文件分開放在不同磁碟,因為二進位文件可以用來進行時間點恢復,可以儘可能保證丟失更少的數據,如果二進位文件也丟失,則可能會丟失大量數據;
      • 在數據恢復操作完成之後一定要再進行一次數據的全備份,保證數據安全;

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

-Advertisement-
Play Games
更多相關文章
  • 相關的基本概念: 1、任務棧(Task) 若幹個Activity的集合的棧表示一個Task。 棧不僅僅只包含自身程式的Activity,它也可以跨應用包含其他應用的Activity,這樣有利於保障用戶體驗,維護用戶操作體驗上的完整性。例如:微信ActivityA 分享文章到QQActivityB,兩 ...
  • 需求概述: 在屏幕上用手指畫出一個區域,返回所圈的區域坐標。 技術實現: 自定義View,設置畫筆及對應參數,在onTouchEvent()回調函數里,對觸摸事件進行判斷。畫出矩形圖形。 代碼: 自定義View: 調用時,只需要在onCreate()函數里,直接添加就可以: 根據需要可以在自定義類中 ...
  • 阿裡雲最近推出了移動熱修複服務,聽說這個服務傻瓜式接入,性能相對較好,對新技術比較好奇的我決定嘗試一下。 移動熱修複.png 移動熱修複.png 首先,需要開通這個服務,創建應用 創建應用.png 創建應用.png 然後,在項目中接入服務。按照文檔所述,第一步:gradle遠程倉庫依賴, 打開項目找 ...
  • 一、NSThread基本概念 NSThread是基於線程使用,輕量級的多線程編程方法(相對GCD和NSOperation),一個NSThread對象代表一個線程,需要手動管理線程的生命周期,處理線程同步等問題。 二、創建、啟動線程 1、動態實例化 - 先創建再人工啟動 2、靜態實例化 - 創建後自啟 ...
  • 公司的apk越做越大。。。作為一個有追求的程式員,我覺得有必要給apk瘦身了。。。 優化之前,先來分析一下apk結構,下麵附上一張apk結構圖: apk結構.png apk結構.png 由於我這個項目集成了百度地圖、百度導航。。。所以assets和lib各自變態的占了12M+,有種蛋蛋的憂傷。。。百 ...
  • 轉載請標明出處:http://blog.csdn.net/zhaoyanjun6/article/details/73468287 本文出自 "【趙彥軍的博客】" 在 Fiddler 中自帶了一個 QuickExec 命令行,用戶可以直接輸入並快速執行腳本命令。 常見命令 help 打開官方的使用頁 ...
  • 經常需要註釋,取消註釋代碼 Ctrl + / 對每段代碼前面添加或者取消 // Ctrl + Shift + / 對代碼添加 或取消 /* */ 實用快捷鍵,持續更新中... ... ...
  • 一,代碼。 - (void)viewDidLoad { [super viewDidLoad]; // Do any additional setup after loading the view, typically from a nib. NSLog(@"--產生隨機數 %@",[self ge ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...