亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

MySQL數(shù)據(jù)誤刪或者誤更新如何恢復詳細步驟(一看就會)

 更新時間:2024年10月30日 09:52:09   作者:家鄉(xiāng)的落日  
本文主要為開發(fā)人員提供在測試環(huán)境中恢復近期誤操作的少量數(shù)據(jù)的方法,首先介紹了如何下載并安裝MyFlash工具,然后詳細講解了如何利用該工具和MySQL的binlog日志來恢復誤刪或誤更新的數(shù)據(jù),介紹的非常詳細,需要的朋友可以參考下

本篇文章適用場景

①、測試環(huán)境少量近期誤刪除或者誤更新的數(shù)據(jù)恢復。

②、測試環(huán)境少量從庫數(shù)據(jù)不一致問題。

備注:大量數(shù)據(jù)的恢復或者復制還是需要使用備份數(shù)據(jù),例如使用mysqldump或者Mydumper、mysqlshell。(本篇文章對此不做討論)

警告:數(shù)據(jù)恢復為DBA專業(yè)人員負責處理的事情,本文章僅為開發(fā)人員測試環(huán)境恢復近期誤操作的少量數(shù)據(jù)提供參考。
請對生產(chǎn)環(huán)境數(shù)據(jù)心存敬畏~

一、下載MyFlash工具

# 創(chuàng)建文件夾
mkdir  /web
cd /web

# 下載壓縮包
wget https://codeload.github.com/Meituan-Dianping/MyFlash/zip/master 

# 安裝編譯相關軟件
yum install gcc -y
yum install glib2 glib2-devel -y

# 解壓縮包
unzip master

# 進入軟件目錄
cd /web/MyFlash-master

# 編譯
sh build.sh

編譯完成后:

驗證:

cd /web/MyFlash-master/binary
./flashback --help

輸入:

MyFlash工具 安裝完成

二、誤刪數(shù)據(jù)恢復

先檢查MySQL有沒有開啟binlog日志

SHOW VARIABLES LIKE 'log_%';

如果發(fā)現(xiàn)數(shù)據(jù)庫未開啟binlog,那么這次恢復數(shù)據(jù)的旅程到此結束~

下面進入亡羊補牢時刻 (如果已經(jīng)開啟了 跳過這個步驟)。

打開MySQL的binlog日志:

# 找到MySQL的配置文件(一般情況下這樣都能找到,找不到就要去問DBA或者運維了)
find / -name my.cnf

一般情況下都是在 下面這個目錄

添加配置:

vi /etc/my.cnf

添加一下配置

# 如果有集群這個id不用重復
server_id =6
# binlog日志位置
log_bin =/web/mysql/binlog/mysql-bin
# binlog日志格式
binlog_format =row

重啟MysQL

# 如果 systemctl 無法重啟  就直接進入mysqld所在的目錄重啟
systemctl restart mysqld

演示誤刪除數(shù)據(jù)

先了解一些命令 后續(xù)要用到

# 查看所有binglog日志
SHOW MASTER LOGS;

# 當前使用的日志
show master status;

# 查看日志記錄
show binlog events in '日志文件名';

下面開始演示:

先看下當前使用的binlog日志是哪個

# 當前使用的日志
show master status;

可以看到我目前的數(shù)據(jù)庫使用的是 mysql-bin.000003 這個binlog日志

現(xiàn)在我有一張表 t_ph_uc_login

假如我誤刪了 t_ph_uc_login 表中的某條數(shù)據(jù)

這里我刪除 id為 10f7a6c619e14b228df0e226bd84db5c 的數(shù)據(jù)

DELETE FROM `t_ph_uc_login` WHERE id = '10f7a6c619e14b228df0e226bd84db5c';

此時再查已經(jīng)查不到這條數(shù)據(jù)了:

一般情況下我們并不知道到底刪除的是哪條數(shù)據(jù),更不知道刪除數(shù)據(jù)的id。

我一開始說的前提是這種方法適合最近誤操作的數(shù)據(jù)恢復。

下面我們去查看binlog日志。

# 查看日志記錄
SHOW BINLOG EVENTS IN 'mysql-bin.000003';  

我查到了3258行,經(jīng)常更新的表一定比這個數(shù)值大得多。所以我們要查看最后幾十行就行。

這里利用分頁查看最后幾百條數(shù)據(jù):

SHOW BINLOG EVENTS IN 'mysql-bin.000003' LIMIT 300 OFFSET 3000;

我們可以在最后幾行中找到 刪除相關的語句,并記錄下事務開始設置時的位置 (Pos列的數(shù)字),和事務提交時的位置(End_log_pos列的數(shù)字)。

**注意圖中藍色標注框 **
開始: 11138303
結束: 11138917

利用MyFlash工具 反寫SQL

delete語句反寫成insert語句

cd /web/MyFlash-master/binary
./flashback --databaseNames="phoenix-saas" --tableNames="t_ph_uc_login" --sqlTypes="delete" --start-position=11138303 --stop-position=11138917 --binlogFileNames=/web/mysql/binlog/mysql-bin.000003  --outBinlogFileNameBase=/web/recover.log

注意:上面數(shù)據(jù)庫名稱,表名稱,sql類型 要根據(jù)自身需求改動,輸出的文件也可以根據(jù)需求改動,我這里就輸出在/web目錄下了

尤其需要注意 --start-position 和 -stop-position 的數(shù)值 如果填的不對 很可能會報下面的錯

如果報了下面的錯就要好好檢查下 --start-position 和 -stop-position 的數(shù)值 取的對不對了

Segmentation fault (core dumped)

如果執(zhí)行成功 就能看到下面紅框的文件:

由于MyFlash工具反寫的數(shù)據(jù)也是二進制文件,所以還需要使用MySQL自帶的 mysqlbinlog工具來執(zhí)行

這里還可以用mysqlbinlog把二進制文件recover.log.flashback 解析成文本文件看下(這一步僅僅是看看 恢復數(shù)據(jù)可跳過這步)

# 先找一下mysqlbinlog在哪
find / -name mysqlbinlog
# 我的mysqlbinlog在/web/mysql/bin/mysqlbinlog文件夾中
cd /web/mysql/bin
# 解析查看二進制文件recover.log.flashback 
mysqlbinlog -v /web/recover.log.flashback

可以看到MyFlash工具 已經(jīng)把

上面我執(zhí)行的delete語句反寫成INSERT語句了

DELETE FROM `t_ph_uc_login` WHERE id = '10f7a6c619e14b228df0e226bd84db5c';

利用mysqlbinlog 執(zhí)行反寫的sql二進制文件

最后一步利用mysqlbinlog 工具執(zhí)行 反寫的二進制文件 recover.log.flashback

# 先到 mysqlbinlog 所在的文件夾
cd /web/mysql/bin

# 恢復數(shù)據(jù)
mysqlbinlog  -v /web/recover.log.flashback | mysql -u用戶名 -p密碼

注意上面要輸入自己數(shù)據(jù)庫的用戶名和密碼

如果不報錯 就說明數(shù)據(jù)恢復完成了。

如果報錯下面的錯:

ERROR 1782 (HY000) at line 17: @@SESSION.GTID_NEXT cannot be set to ANONYMOUS when @@GLOBAL.GTID_MODE = ON.

使用下面的語句查看是否開啟了 全局事務ID (GTID) 功能

SELECT @@GLOBAL.GTID_MODE;

下圖就是開啟了。

可以 通過參數(shù) --skip-gtids 跳過,不把gtid信息寫到binlog中。不過如果數(shù)據(jù)庫是多主或者一主多從的情況可能從庫會出現(xiàn)數(shù)據(jù)不一致。

#  --skip-gtids  跳過gtid信息
mysqlbinlog  -v /web/recover.log.flashback  --skip-gtids  | mysql -u用戶名 -p密碼

恢復完成

執(zhí)行完成后 再查詢被刪除的數(shù)據(jù),可以發(fā)現(xiàn)已經(jīng)恢復了。

三、誤更新數(shù)據(jù)恢復

基本流程和上面誤刪除的恢復流程一致

演示誤更新數(shù)據(jù)

還是拿id為 10f7a6c619e14b228df0e226bd84db5c 這條數(shù)據(jù)測試:

誤更新前 user_id = 04f1fd53a4554e3fb5c9a40463a4ea4c

開始誤更新

UPDATE `t_ph_uc_login` SET user_id = '小明' WHERE id = '10f7a6c619e14b228df0e226bd84db5c';

誤更新后:

假如我們不知道 誤更新之前的user_id 是什么

查看binlog最近的更新記錄 ,確定起始、結束位置

SHOW MASTER STATUS;

SHOW BINLOG EVENTS IN 'mysql-bin.000004'  

這里再細說下 找position的技巧吧

這次是更新 那就先找 Update_rows ,找到后 往上找 INFO列的 BEGIN,再往上一行, SET @@SESSION.GTID_NEXT 設置全局事務ID的這行就是這次更新事務的始位置。開始position就確定了。

開始: 1159

順著Update_rows 再往下找,找到INFO列的 最近的一個COMMIT,這行的 End_log_pos列就是 結束position

結束: 1929

利用MyFlash工具 反寫SQL

這里update 還是會被反寫成update

cd /web/MyFlash-master/binary
./flashback --databaseNames="phoenix-saas" --tableNames="t_ph_uc_login" --sqlTypes="update" --start-position=1159 --stop-position=1929 --binlogFileNames=/web/mysql/binlog/mysql-bin.000004  --outBinlogFileNameBase=/web/recover.log

利用mysqlbinlog 執(zhí)行反寫的sql二進制文件

#  --skip-gtids  跳過gtid信息
mysqlbinlog  -v /web/recover.log.flashback  --skip-gtids  | mysql -u用戶名 -p密碼

恢復完成

再查一下 可以看到 user_id 已經(jīng)恢復了

補充點 flush logs

如果當前數(shù)據(jù)庫 還有大量連接正在更新 可以執(zhí)行flush logs 重新生成新的binlog日志

比如現(xiàn)在的日志名是001 執(zhí)行 flush logs 后 ,會生成一個002的文件 ,并且當前會使用002文件記錄
那你再去找001文件的position時 就不會受到干擾了

四、警告

非專業(yè)DBA請勿在生產(chǎn)環(huán)境操作上述過程~

到此這篇關于MySQL數(shù)據(jù)誤刪或者誤更新如何恢復的文章就介紹到這了,更多相關MySQL數(shù)據(jù)誤刪或者誤更新恢復內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • redhat7通過yum安裝mysql5.7.17教程

    redhat7通過yum安裝mysql5.7.17教程

    這篇文章主要為大家詳細介紹了redhat7通過yum安裝mysql5.7.17教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-01-01
  • MySQL生成日期維度表的sql語句

    MySQL生成日期維度表的sql語句

    這篇文章主要介紹了MySQL生成日期維度表的sql語句,通過存儲過程生成,其次是通過遞歸的公用表表達式生成,需要的朋友可以參考下
    2024-07-07
  • Windows環(huán)境MySQL全量備份+增量備份的實現(xiàn)

    Windows環(huán)境MySQL全量備份+增量備份的實現(xiàn)

    本文主要介紹了Windows環(huán)境MySQL全量備份+增量備份的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2024-08-08
  • mysql中的replace函數(shù)替換字符串問題

    mysql中的replace函數(shù)替換字符串問題

    這篇文章主要介紹了mysql中的replace函數(shù)替換字符串問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • SELECT?*?效率低原理解析

    SELECT?*?效率低原理解析

    這篇文章主要為大家介紹了SELECT?*?效率低原理解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-02-02
  • 數(shù)據(jù)庫SQL腳本文件導入到mysql數(shù)據(jù)庫的兩種方式

    數(shù)據(jù)庫SQL腳本文件導入到mysql數(shù)據(jù)庫的兩種方式

    MySQL作為一種關系型數(shù)據(jù)庫管理系統(tǒng),它是在Web服務器中廣泛使用的,它把數(shù)據(jù)存儲在表中,這篇文章主要介紹了數(shù)據(jù)庫SQL腳本文件導入到mysql數(shù)據(jù)庫的兩種方式,需要的朋友可以參考下
    2025-04-04
  • 一文讀懂navicat for mysql基礎知識

    一文讀懂navicat for mysql基礎知識

    Navicat是一個強大的MySQL數(shù)據(jù)庫管理和開發(fā)工具。Navicat為專業(yè)開發(fā)者提供了一套強大的足夠尖端的工具,但它對于新用戶仍然是易于學習。本文重點給大家介紹navicat for mysql基礎知識,感興趣的朋友一起學習吧
    2021-05-05
  • mysql如何將sql查詢的結果以百分比展示出來

    mysql如何將sql查詢的結果以百分比展示出來

    這篇文章主要給大家介紹了關于mysql如何將sql查詢的結果以百分比展示出來的相關資料,用到了MySQL字符串處理中的兩個函數(shù)concat()和left()實現(xiàn)查詢結果以百分比顯示,需要的朋友可以參考下
    2023-08-08
  • MySQL性能優(yōu)化之max_connections配置參數(shù)淺析

    MySQL性能優(yōu)化之max_connections配置參數(shù)淺析

    這篇文章主要介紹了MySQL性能優(yōu)化之max_connections配置參數(shù)淺析,本文著重講解了3種配置max_connections參數(shù)的方法,需要的朋友可以參考下
    2014-07-07
  • 常見的十種SQL語句性能優(yōu)化策略詳解

    常見的十種SQL語句性能優(yōu)化策略詳解

    這篇文章主要介紹了常見的十種SQL語句性能優(yōu)化策略詳解,SQL語句性能優(yōu)化是提高數(shù)據(jù)庫查詢效率的關鍵步驟,可以減少查詢時間,提高系統(tǒng)響應速度,本文將介紹一些常見的SQL語句性能優(yōu)化技巧,包括索引的使用、合理的查詢條件、避免全表掃描等,需要的朋友可以參考下
    2023-10-10

最新評論