lvm快照備份資料庫(Mysql5.7)

来源:https://www.cnblogs.com/1312862978Hg/archive/2018/09/23/9693291.html
-Advertisement-
Play Games

備份的目的 能夠防止由於機械故障以及人為誤操作帶來的數據丟失,例如將資料庫文件保存在了其它地方。 備份的分類 以操作過程中服務的可用性分: 冷備份:cold backup mysql服務關閉,mysql離線 溫備份:warm backup mysql服務線上,但是不允許寫請求,例如 read loc ...


 

備份的目的

 能夠防止由於機械故障以及人為誤操作帶來的數據丟失,例如將資料庫文件保存在了其它地方。

備份的分類

以操作過程中服務的可用性分:

冷備份:cold backup mysql服務關閉,mysql離線
溫備份:warm backup mysql服務線上,但是不允許寫請求,例如 read lock,線上的某些功能需要中止。
熱備份:hot backup 備份同時,業務讀寫請求繼續,業務不受干擾。(沒有絕對的熱備份,無限接近,停止的時間忽略不計)


myisam :不支持熱備
innodb : 需要專用工具

以操作方式區分:

邏輯備份: 備份的是建表、建庫、插入等操作所執行SQL語句(DDL DML DCL),適用於中小型資料庫,效率相對較低(相對複雜,且在恢復過程中容易丟失數據,不推薦使用)

物理備份: 直接複製資料庫文件,適用於大型資料庫環境,不受存儲引擎的限制,
但不能恢復到不同的MySQL版本。(推薦使用)

 lvm快照備份的優缺點

優點:
幾乎是熱備 (創建快照前把表上鎖,創建完後立即釋放)
支持所有存儲引擎
備份速度快
無需使用昂貴的商業軟體(它是操作系統級別的)

缺點:
可能需要跨部門協調(使用操作系統級別的命令,DBA一般沒許可權)
無法預計服務停止時間
數據如果分佈在多個捲上比較麻煩 (針對存儲級別而言)

lvm 快照備份原理:

 LVM對LV提供的快照功能,只對LVM有效。
當一個snapshot創建的時候,僅拷貝 原始捲 里數據的 元數據(meta-data)。因此建立快照的速度非常快

創建的時候,並不會有數據的物理拷貝,因此 snapshot的創建幾乎是實時的,當原始捲上有寫操作執行時,
snapshot 跟蹤原始捲塊的改變,這個時候原始捲上將要改變的數據在 改變之前被拷貝到 snapshot預留的空間里,
因此這個原理的實現叫做寫時複製 (copy-on-write)。

 在寫操作寫入塊之前,將原始數據移動到 snapshot空間里,這樣就保證了所有的數據在snapshot創建時保持一致。
而對於snapshot的讀操作,如果是讀取數據塊是沒有修改過的,那麼會將讀操作直接重定向到原始捲上,如果是要
讀取已經修改過的塊,那麼就讀取拷貝到snapshot中的塊。

LVM 快照備份流程

LVM快照: 鎖表時間接近熱備
1. 加全局讀鎖
mysql> flush tables with read lock;
2.創建快照, lvcreate -L 500M -s -n lv-mysql-snap /dev/datavg/lv-mysql ;
3.刷新二進位日誌 mysql> flush logs
4 釋放鎖  mysql>unlock tables
5. 掛載 快照設備 ,並從快照設備中,對資料庫文件進行打包與 壓縮
6、卸載快照設備
7、 移除快照設備 lvremove -f /dev/datavg/lv-mysql-snap
產生了一份新的 二進位日誌。
此時,手動插入 幾條數據,修改幾條數據 ======》 體現最新的 二進位日誌中。!

模擬崩潰: 

停止服務,刪除 資料庫所有文件 ( 二進位日誌不要和資料庫數據放在同一目錄 )
要求,恢復所有數據,包括 剛纔 新增 和 修改了的 數據。

恢復流程:

1、恢復最近的一次 完全備份, mysql-2018-9-19-full.tar.gz /mysql 解壓。
2、將最近的一份二進位日誌 進行導出 mysqlbinlog /data/mysql-binlog/mysql.000025 > /tmp/a.sql
3、啟動mysql服務(產生一份新的二進位日誌 ),登錄mysql
4、設置 臨時 停止記錄 二進位 日誌。 mysql> set session sql_log_bin=0;
5、mysql> source /tmp/a.sql;
6、mysql> set session sql_log_bin=1; 重新開啟二進位日誌功能

至此,恢復完成! 用 select 語句 進行 查詢驗證,看數據是否恢復 。

 


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

-Advertisement-
Play Games
更多相關文章
  • 這邊只演示一下最新系統的安裝過程,設置之類的和以前講的Kali以及CentOS大同小異: 和CentOS對比一下體積: 自帶Python版本 ...
  • 這篇文章包含電腦網路基礎,Linux常用系統命令,Linux用戶與組許可權,Linux進程管理,Linux磁碟管理,IP地址虛擬網路,Linux軟體包管理。是我學習過程中的練習和我的理解。目前學到Linux用戶與組許可權,這篇文章會不斷更新。 ...
  • 作為一個剛剛接觸linux系統的小白來說,VMware虛擬機安裝好CentOS6.5系統後,純凈的系統多克隆幾份出來方便後期做試驗。克隆步驟很簡單,克隆後出現的問題是克隆後的網卡MAC地址和原系統MAC地址一樣,在區域網內會有衝突,需要更改克隆後的MAC地址,不然網卡起不起來。今天教大家如何修改,具 ...
  • 有時候上傳的文件在linux上ls顯示的時亂碼,原因可能是系統語言編碼問題,以Linux centos6.5為例,解決方法如下: 1、在root(皇帝)許可權下更改: 查看當前所有語言環境:locale -a 查看當前系統語言環境:echo $LANG 2、編輯i18n配置文件: vi /etc/sy ...
  • 我的系統的電腦是win10系統,筆記本 下載了一個wifi共用大師,但是wifi總是自動斷,於是就找了找問題所在 在網上看了許多方案,大多數都是 在 電源管理 把【允許電腦關閉此設備以節約電源】的勾去掉 但是其實是沒有用的 解決方案是 首先 先 win+R 運行 輸入cmd 進去dos界面,然後輸 ...
  • 1、方法一、修改網路配置文件 ①cd /etc/sysconfig/network-scripts ②cp ifcfg-eth0 ./ifcfg-eth0.bak //修改前先備份 第一個乙太網卡對應的網路配置文件:ifcfg-eth0 ifcfg-eth0配置如下: vi /etc/sysconf ...
  • 一. 概述 如果創建了一個目錄或文件,有時會需要改變它的安全性設置,在linux系統上有一些工具可以完成這任務,包括使用chmod命令改變已有預設許可權,分別能對屬主,屬組,其它用戶的許可權的控制分別以讀取、寫入、執行3種許可權來區分設置,還有使用chown,chgrp來改變預設屬主屬組關係。 1 . 改 ...
  • 一、前言 要清空表中數據,100w條數據以上的表,開始我們使用delete from t_user進行刪除,這樣操作太慢了,需要等好長時間,如果數據量更大,那麼我們要等的時間無法想象。 可以用以下方法進行刪除 假設要刪除的原表為SOURCE_T 二、解決辦法 第一步:生成中間表 1 create t ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...