日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

mysql 实例启动利用binlog恢复_mysql利用binlog进行数据恢复

發布時間:2024/9/27 数据库 28 豆豆
生活随笔 收集整理的這篇文章主要介紹了 mysql 实例启动利用binlog恢复_mysql利用binlog进行数据恢复 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

mysql利用binlog進行數據恢復

最近線上誤操作了一個數據,由于是直接修改的數據庫,所有唯一的恢復方式就在mysql的binlog。binlog使用的是ROW模式,即受影響的每條記錄都會生成一個sql。同時利用了

binlog基本配置和格式

binlog基本配置

binlog需要在mysql的配置文件的mysqld節點中進行配置:

# 日志中的Serverid

server-id= 1

# 日志路徑

log_bin= /var/log/mysql/mysql-bin.log

# 保存幾天的日志

expire_logs_days= 10

# 每個binlog的大小

max_binlog_size = 1000M

#binlgo模式

binlog_format=ROW

# 默認是所有記錄,可以配置哪些需要記錄,哪些不記錄

#binlog_do_db= include_database_name

#binlog_ignore_db= include_database_name

查看binlog狀態

SHOW BINARY LOGS; 查看binlog文件

SHOW VARIABLES LIKE '%log_bin%' 查看日志狀態

SHOW MASTER STATUS 查看日志文件位置

binlog的三種格式

1.ROW

針對行記錄日志,每行修改產生一條記錄。

優點:上下文信息比較全,恢復某條誤操作時可以直接在日志中查找到原文信息,對于主從復制支持好。

缺點:輸出非常大,如果是Alter語句將產生大量的記錄

格式如下:

DELETE FROM `back`.`sys_user` WHERE `deptid`=27 AND `status`=1 AND `account`='admin' AND `name`='張三' AND `phone`='18200000000' AND `roleid`='1' AND `createtime`='2016-01-29 08:49:53' AND `sex`=2 AND `email`='sn93@qq.com' AND `birthday`='2017-05-05 00:00:00' AND `avatar`='girl.gif' AND `version`=25 AND `password`='ecfadcde9305f8891bcfe5a1e28c253e' AND `salt`='8pgby' AND `id`=1 LIMIT 1; #start 4 end 796 time 2018-10-12 17:03:19

2.STATEMENT

針對sql語句的,每條語句產生一條記錄

優點:產生的日志量比較小,主從版本可以不一致

缺點:主從有些語句不能支持,像自增主鍵和UUID這種類型的

格式如下:

delete from `sys_role`;

3.MIX

結合了兩種的優點,一般情況下都采用STATEMENT模式,對于不支持的語句采用ROW模式

轉換成sql

mysql自帶的mysqlbinlog

由于binlog是二進制的,所以需要先轉換成文本文件,一般可以采用Mysql自帶的mysqlbinlog轉換成文本。

mysqlbinlog --no-defaults --base64-output='decode-rows' -d room -v mysql-bin.011012 > /root/binlog_2018-10-10

參數說明

--no-defaults 為了防止報錯:mysqlbinlog: unknown variable 'default_character_set=utf8mb4'

--base64-output='decode-rows' 和-v一起使用, 進行base64解碼

其他有很多用來限定范圍的參數,比如數據庫,起始時間,起始位置等等。這些參數在查找誤操作的時候非常有用。

binlog的基本塊如下:

# at 417750

#181007 1:50:38 server id 1630000 end_log_pos 417844 CRC32 0x9fc3e3cd Querythread_id=440109962exec_time=0error_code=0

SET TIMESTAMP=1538877038/*!*/;

BEGIN

# at 417750

指明的當前位置相對文件開始的偏移位置,這個在mysqlbinlog命令中可以作為--start-position的參數

#181007 1:50:38 server id 1630000 end_log_pos 417844 CRC32 0x9fc3e3cd Querythread_id=440109962exec_time=0error_code=0

181007 1:50:38指明時間為18年10月7號1:50:38,serverid也就是你在配置文件中的配置的,end_log_pos 417844,這個塊在417844結束。thread_id執行的線程id,exec_time執行時間,error_code錯誤碼

SET TIMESTAMP=1538877038/!/;

BEGIN

具體的執行語句

一行記錄產生的日志如下所示

# at 417750

#181010 9:50:38 server id 1630000 end_log_pos 417844 CRC32 0x9fc3e3cd Querythread_id=440109962exec_time=0error_code=0

SET TIMESTAMP=1539136238/*!*/;

BEGIN

/*!*/;

# at 417844

#181010 9:50:38 server id 1630000 end_log_pos 417930 CRC32 0xce36551b Table_map: `goods`.`good_info` mapped to number 129411

# at 417930

#181010 9:50:38 server id 1630000 end_log_pos 418030 CRC32 0x5827674a Update_rows: table id 129411 flags: STMT_END_F

### UPDATE `goods`.`good_info`

### WHERE

### @1='2018:10:07' /* DATE meta=0 nullable=0 is_null=0 */

### @2=9033404 /* INT meta=0 nullable=0 is_null=0 */

### @3=1 /* INT meta=0 nullable=0 is_null=0 */

### @4=8691108 /* INT meta=0 nullable=0 is_null=0 */

### @5=9033404 /* INT meta=0 nullable=0 is_null=0 */

### @6=20 /* LONGINT meta=0 nullable=0 is_null=0 */

### @7=1538877024 /* TIMESTAMP(0) meta=0 nullable=0 is_null=0 */

### SET

### @1='2018:10:07' /* DATE meta=0 nullable=0 is_null=0 */

### @2=9033404 /* INT meta=0 nullable=0 is_null=0 */

### @3=1 /* INT meta=0 nullable=0 is_null=0 */

### @4=8691108 /* INT meta=0 nullable=0 is_null=0 */

### @5=9033404 /* INT meta=0 nullable=0 is_null=0 */

### @6=21 /* LONGINT meta=0 nullable=0 is_null=0 */

### @7=1538877024 /* TIMESTAMP(0) meta=0 nullable=0 is_null=0 */

# at 418030

#181010 9:50:38 server id 1630000 end_log_pos 418061 CRC32 0x468fb30e Xid = 212760460521

COMMIT/*!*/;

# at 418061

一行記錄產生的日志如上所示。以SET TIMESTAMP=1539136238/*!*/;開始,以COMMIT/*!*/;結尾。我們可以根據兩個at指明的位置來限定范圍。

注意一條記錄開始的SET TIMESTAMP之前的# at 417750和結尾的COMMIT之后的# at 418061

利用binlog2sql

binlog2sql官網介紹:從MySQL binlog解析出你要的SQL。根據不同選項,你可以得到原始SQL、回滾SQL、去除主鍵的INSERT SQL等。

基本使用如下:

python binlog2sql.py -hlocalhost -P3306 -udev -p'\*' -d room -t room_info --start-file='mysql-bin.011012' --start-position 129886892 --stop-position 130917280 > rollback.sql

具體的使用我就不講解了github上講解的十分清楚,主要看下很多用來篩選的條件,比如起止時間--start-datetime/--stop-datetime,表名限定-t,數據庫限定-d,語句限定--sql-type,主要說說我遇到的一些問題。

mysql的binlog模式

這里需要設置為ROW,因為ROW模式有原來的信息,如果可以直接利用binlog2sql反向生成回滾sql,如果是STATEMENT無法生成,需要利用的mysql定時備份的文件再去做回滾

恢復數據的具體操作

因為當時線上執行的是一條update語句,沒有唯一鍵索引的。導致有兩千多條記錄被更新。語句如下:

update room_info set status=1 where status=2;

根據操作時間先定位對應的binlog文件

我記得當時操作的時間大概的是上午9多左右,所以去找對應的binlog文件最后修改時間大于9點并且時間最接近的一個文件。使用linux的ll命令查看文件的修改時間。

篩選具體的數據庫

因為一個mysql實例的所有binlog文件是在一個文件中的,所以我們先要去除其他不想關的數據庫。利用-d參數來指明數據實例。然后在利用開始時間(--start-datetime)和結束時間(--stop-datetime)來進一步篩選

mysqlbinlog --no-defaults -v --base64-output='decode-rows' -d room --start-datetime='2018-10-10 9:00:00' --stop-datetime='2018-10-10 10:00:00' mysql-bin.011012>temp.sql

壓縮取回文件分析

zip temp.zip temp.sql && sz temp.zip

取回文件在本地用文本工具如vscode分析,里面有正則匹配,根據你改動過的特征,比如我有個房間號888888,這個不應該被修改,你就查看這個房間號的修改記錄,ROW模式的語句是Where在前,set在后。利用正則room_id=888888.*show_state=1.*AND show_state=2很快就能匹配到。我當時的語句影響了兩千多條記錄,你根據找到的語句去找開始的SET TIMESTAMP=1539136238的位置之前的at和結尾的COMMIT之后的at。

利用binlog2sql生成回滾語句

python binlog2sql.py -hlocalhost -P3306 -udev -p'*' -d room -t room_info -B --start-file='mysql-bin.011012' --start-position 129886892 --stop-position 130917280 > rollback.sql

另外

因為我這邊是一條update影響多條的情況,如果是帶唯一鍵的情況下,影響的只有一條記錄,完全沒必要這么麻煩,直接利用binlog2sql帶上-d和-t參數限定數據庫和表,然后利用grep來查找,直接可以得出對應的sql。mysqlbinlog少了一個限定表和限定語句的功能。比如精確到一張表的Delete語句,能減少很多的數據,能快速定位。

創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎

總結

以上是生活随笔為你收集整理的mysql 实例启动利用binlog恢复_mysql利用binlog进行数据恢复的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。