欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

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

本篇文章適用場景

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

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

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

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

一、下載MyFlash工具

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

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

# 安裝編譯相關(guān)軟件
yum install gcc -y
yum install glib2 glib2-devel -y

# 解壓縮包
unzip master

# 進(jìn)入軟件目錄
cd /web/MyFlash-master

# 編譯
sh build.sh

編譯完成后:

驗(yàn)證:

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

輸入:

MyFlash工具 安裝完成

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

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

SHOW VARIABLES LIKE 'log_%';

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

下面進(jìn)入亡羊補(bǔ)牢時(shí)刻 (如果已經(jīng)開啟了 跳過這個(gè)步驟)。

打開MySQL的binlog日志:

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

一般情況下都是在 下面這個(gè)目錄

添加配置:

vi /etc/my.cnf

添加一下配置

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

重啟MysQL

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

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

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

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

# 當(dāng)前使用的日志
show master status;

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

下面開始演示:

先看下當(dāng)前使用的binlog日志是哪個(gè)

# 當(dāng)前使用的日志
show master status;

可以看到我目前的數(shù)據(jù)庫使用的是 mysql-bin.000003 這個(gè)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';

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

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

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

下面我們?nèi)ゲ榭碽inlog日志。

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

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

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

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

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

**注意圖中藍(lán)色標(biāo)注框 **
開始: 11138303
結(jié)束: 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ù)自身需求改動(dòng),輸出的文件也可以根據(jù)需求改動(dòng),我這里就輸出在/web目錄下了

尤其需要注意 --start-position 和 -stop-position 的數(shù)值 如果填的不對(duì) 很可能會(huì)報(bào)下面的錯(cuò)

如果報(bào)了下面的錯(cuò)就要好好檢查下 --start-position 和 -stop-position 的數(shù)值 取的對(duì)不對(duì)了

Segmentation fault (core dumped)

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

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

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

# 先找一下mysqlbinlog在哪
find / -name mysqlbinlog
# 我的mysqlbinlog在/web/mysql/bin/mysqlbinlog文件夾中
cd /web/mysql/bin
# 解析查看二進(jìn)制文件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二進(jìn)制文件

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

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

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

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

如果不報(bào)錯(cuò) 就說明數(shù)據(jù)恢復(fù)完成了。

如果報(bào)錯(cuò)下面的錯(cuò):

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

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

SELECT @@GLOBAL.GTID_MODE;

下圖就是開啟了。

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

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

恢復(fù)完成

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

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

基本流程和上面誤刪除的恢復(fù)流程一致

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

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

誤更新前 user_id = 04f1fd53a4554e3fb5c9a40463a4ea4c

開始誤更新

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

誤更新后:

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

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

SHOW MASTER STATUS;

SHOW BINLOG EVENTS IN 'mysql-bin.000004'  

這里再細(xì)說下 找position的技巧吧

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

開始: 1159

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

結(jié)束: 1929

利用MyFlash工具 反寫SQL

這里update 還是會(huì)被反寫成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二進(jìn)制文件

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

恢復(fù)完成

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

補(bǔ)充點(diǎn) flush logs

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

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

四、警告

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

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

相關(guān)文章

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

    redhat7通過yum安裝mysql5.7.17教程

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

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

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

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

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

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

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

    SELECT?*?效率低原理解析

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

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

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

    一文讀懂navicat for mysql基礎(chǔ)知識(shí)

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

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

    這篇文章主要給大家介紹了關(guān)于mysql如何將sql查詢的結(jié)果以百分比展示出來的相關(guān)資料,用到了MySQL字符串處理中的兩個(gè)函數(shù)concat()和left()實(shí)現(xiàn)查詢結(jié)果以百分比顯示,需要的朋友可以參考下
    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ù)庫查詢效率的關(guān)鍵步驟,可以減少查詢時(shí)間,提高系統(tǒng)響應(yīng)速度,本文將介紹一些常見的SQL語句性能優(yōu)化技巧,包括索引的使用、合理的查詢條件、避免全表掃描等,需要的朋友可以參考下
    2023-10-10

最新評(píng)論