MySQL-Xtrabackup備份還原

来源:https://www.cnblogs.com/xsuid/archive/2018/08/05/9426257.html
-Advertisement-
Play Games

前言通常我們都是使用xtrabackup工具來備份資料庫,它是一個專業的備份工具,先來簡單介紹下它。Xtrabackuppercona提供的mysql資料庫備份工具,惟一開源的能夠對innodb和xtradb資料庫,它的增量備份不是基於二進位日誌文件來還原數據的,是基於mysql數據塊。特點:備份還... ...



前言

通常我們都是使用xtrabackup工具來備份資料庫,它是一個專業的備份工具,先來簡單介紹下它。

Xtrabackup

percona提供的mysql資料庫備份工具,惟一開源的能夠對innodb和xtradb資料庫,它的增量備份不是基於二進位日誌文件來還原數據的,是基於mysql數據塊。

特點:

  • 備份還原過程快速、可靠
  • 備份過程不會打斷正在執行的事務
  • 能夠基於壓縮等功能節約磁碟空間和流量
  • 自動實現備份檢驗
  • 開源,免費

Xtrabackup用法

備份時選項

xtrabackup --backup

--user:該選項表示備份賬號

--password:該選項表示備份的密碼

--host:該選項表示備份資料庫的地址

--databases:該選項接受的參數為數據名,如果要指定多個資料庫,彼此間需要以空格隔開;如:"xtra_test dba_test",同時,在指定某資料庫時,也可以只指定其中的某張表。如:"mydatabase.mytable"。該選項對innodb引擎表無效,還是會備份所有innodb表

--defaults-file:該選項指定從哪個文件讀取MySQL配置,必須放在命令行第一個選項位置

--incremental:該選項表示創建一個增量備份,需要指定--incremental-basedir

--incremental-basedir:該選項指定為前一次全備份或增量備份的目錄,與--incremental同時使用

--incremental-dir:該選項表示還原時增量備份的目錄

--include=name:指定表名,格式:databasename.tablename

Prepare於準備選項

prepare

--apply-log:此選項作用是通過回滾未提交的事務及同步已經提交的事務至數據文件使數據文件處於一致性狀態

--use-memory:該選項表示和--apply-log選項一起使用,prepare 備份的時候,xtrabackup做crash recovery分配的記憶體大小,單位位元組。也可(1MB,1M,1G,1GB),推薦1G

--export:表示開啟可導出單獨的表之後再導入其他Mysql中

--redo-only:此選項在prepare base full backup,往其中merge增量備份時候使用


還原時選項

--copy-back:複製

--move-back:移動

備份生產的相關文件

1)xtrabackup_info:innobackupex工具執行時的相關信息,包括版本,備份選項,備份時長,備份LSN,BINLOG的位置

2)xtrabackup_checkpoints:備份類型(如完全或增量)、備份狀態(如是否已經為prepared狀態)和LSN(日誌序列號)範圍信息,每個InnoDB頁(通常為16k大小)都會包含一個日誌序列號,即LSN。LSN是整個資料庫系統的系統版本號,每個頁面相關的LSN能夠表明此頁面最近是如何發生改變的

3)xtrabackup_binlog_info:MySQL伺服器當前正在使用的二進位日誌文件及至備份這一刻為止二進位日誌事件的位置,可利用實現基於binlog的恢復

4)backup-my.cnf:備份命令用到的配置選項信息

5)xtrabackup_logfile:備份生成的日誌文件


還原註意事項

1.datadir目錄必須為空。除非指定innobackupex --force-non-emptydirectorires選項指定,否則--copy-backup選項不會覆蓋

2.restore還原之前,必須shutdown停止 MySQL服務,不能將一個運行中的實例restore到datadir目錄中

3.修改恢覆文件的許可權為mysql

4.最後一次增量備份還原要回滾事務

5.二進位安裝的mysql要是出現停止不了服務就用killall –9 mysqld 殺掉進程進而實現停止服務

實戰

規劃

1、兩台主機17和37,其中17當主mysql伺服器,37用來還原的主機,

2、目錄,1個存放完整備份的目錄,N個存放增量備份的目錄

image

說明:

full目錄:  存放完全備份

inc1目錄:存放第一次的增量備份

inc2目錄:存放第二次的增量備份


備份階段

1、完全備份資料庫

xtrabackup -pcentos --backup --target-dir=/backups/full/
# --backup表示備份
# --target-dir=填寫備份到哪裡

2、往表中增加數據

mysql -pcentos hellodb -e "insert students (name,age) values('gaodao01',20)"

image
3、第一次增量備份

xtrabackup –pcentos --backup --target-dir=/backups/inc1/ --incremental-basedir=/backups/full
# --incremental-basedir表示基於誰的增量備份,寫上上一次的備份路徑
#

image

4、再次修改數據表

mysql -pcentos hellodb -e "insert students (name,age) values('gaodao02',21)"

image

5、第二次增量備份

xtrabackup -pcentos --backup --target-dir=/backups/inc2/ --incremental-basedir=/backups/inc1/

image

還原階段

說明:還原的時候我們要考慮到前幾次不要回滾,最後一次還原要回滾,還原主機要安裝xtrabackup工具

1、把備份的目錄傳送到要還原的主機上

scp -r /backups/ 192.168.43.37:/

2、停服務並清空mysql數據

systemctl stop mysqld
rm -rf /app/mysql/*

3、完全備份的預處理

xtrabackup  --prepare --apply-log-only --target-dir=/backups/full
# --prepare 表示還原
# --apply-log-only 表示不回滾

4、第一次增量備份預處理

xtrabackup --prepare --apply-log-only --target-dir=/backups/full --incremental-dir=/backups/inc1
# 同樣不回滾

5、第二次增量備份預處理

xtrabackup --prepare  --target-dir=/backups/full --incremental-dir=/backups/inc2
# 這是最後一次,所以要回滾不完整的事務

6、複製處理好的數據到真正的存放資料庫目錄下

xtrabackup --copy-back --target-dir=/backups/full
# 它會根據你的配置文件my.cnf來讀取存放位置

7、修改資料庫文件許可權

chown -R mysql.mysql /app/mysql/

以上還原到了備份時的狀態,我們備份完二次增量後又加了條記錄,還沒來得急三次增量備份就宕機了,所以再次利用二進位日誌文件還原到最新狀態

8、通過二進位文件還原到最新狀態

1)以下圖中文件記錄了還原到的位置

image

2)從原主機導出二進位文件日誌

mysqlbinlog --start-position=1039 /app/logs/mysql-bin.000003 >/app/binlog.sql

3)scp傳送到目標主機來還原

  • 首先在配置文件中加入禁止所有人訪問選項
skip-networking
  • 啟動服務
systemctl start mysqld
  • 導入二進位日誌
mysql -pcentos <binlog.sql

4)進入資料庫驗證

image

5)OK 恢復完成,刪除配置文件中的skip-networking並重啟服務

systemctl restart mysqld




更多精彩內容請移步

http://www.cnblogs.com/xsuid/


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

-Advertisement-
Play Games
更多相關文章
  • 首先我們的使用的是linux的 centOS6 版本 安裝mysql: 1、查看有沒有安裝包 2、進行安裝mysql:一般我們在伺服器端安裝的都是服務端( mysql-server 或 mysql-devel) 或者你也可以安裝客戶端 運行後會進入安裝界面,一頓操作之後,安裝完成。 3、進行字元集和 ...
  • 軟體操作命令 1. 軟體包管理器: yum 2. 安裝軟體: yum install xxx 3. 卸載軟體: yum remove xxx 4. 搜索軟體: yum serach xxx 5. 清理緩存: yum clear packages 6. 列出已安裝: yum list 7. 軟體包: ...
  • 眾所周知在預設參數情況下Linux對高併發支持並不好,主要受限於單進程最大打開文件數限制、內核TCP參數方面和IO事件分配機制等。下麵就從幾方面來調整使Linux系統能夠支持高併發環境。 iptables相關 如非必須,關掉或卸載iptables防火牆,並阻止kernel載入iptables模塊。這 ...
  • 開發的時候遇到一個問題,伺服器一旦重啟,項目生成的文件就丟失了,感覺很莫名其妙..一開始猜測是文件流沒有關閉,檢查了代碼,感覺沒毛病.於是先看看是關機丟失了文件還是開機被刪除了.下麵的腳本每秒執行一次,把指定目錄下的文件數量寫入到file.txt 中.最後把它加入開機自啟就好了. while tru ...
  • 看了幾篇privoxy的文章,感覺講的都不詳細,在此整理一遍。 註:本文下麵的內容僅討論思路,作為技術交流之用,請勿用作非法途徑. Privoxy是一款帶過濾功能的代理伺服器,針對HTTP、HTTPS協議。通過Privoxy的過濾功能,用戶可以保護隱私、對網頁內容進行過濾、管理cookies,以及攔 ...
  • //簡易ftp客戶端#include <stdio.h> #include <string.h> #include <sys/types.h> #include <sys/socket.h> #include <netinet/in.h> #include <arpa/inet.h> #includ ...
  • Anaconda集合了python,Spyder,Jupyter notebook及conda 包管理器與環境管理器(含常用的panda,numpy等),省去單獨下載的繁瑣步驟,方便使用。 註:如過已經下載過python,可點擊python安裝包,再次setup,選擇uninstall. 如Gean ...
  • 要求:原操作系統代碼里只是支持了日語顯示,需要做的是實現對這個系統的漢字全形支持。 hzk16的介紹以及簡單的使用方法 HZK16字型檔是符合GB2312標準的16×16點陣字型檔,HZK16的GB2312-80支持的漢字有6763個,符號682個。其中一級漢字有3755個,按聲序排列,二級漢字有300 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...