溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

怎么通過日志文件恢復(fù)MySQL數(shù)據(jù)

發(fā)布時間:2022-02-07 15:44:20 來源:億速云 閱讀:154 作者:iii 欄目:開發(fā)技術(shù)

這篇文章主要介紹“怎么通過日志文件恢復(fù)MySQL數(shù)據(jù)”的相關(guān)知識,小編通過實(shí)際案例向大家展示操作過程,操作方法簡單快捷,實(shí)用性強(qiáng),希望這篇“怎么通過日志文件恢復(fù)MySQL數(shù)據(jù)”文章能幫助大家解決問題。

    1、找到最新的 binlog 文件

    進(jìn)入 mysql 命令行執(zhí)行如下命令

    mysql> show master status;
    +------------------+-----------+
    | Log_name         | File_size |
    +------------------+-----------+
    | binlog.000001 |       967 |
    | binlog.000002 |       965 |
    +------------------+-----------+

    一般最新的編號大,上面最新的就是 binlog.000002

    2、找到我們想恢復(fù)數(shù)據(jù)在日志文件里的開始結(jié)束位置

    這里有兩種方式來確定開始位置和結(jié)束位置,一種是使用時間作為開始結(jié)束,一種是使用日志的 position 作為開始結(jié)束位置

    2.1、使用時間范圍

    通過 mysqlbinlog mysql-bin.000002 命令查看日志內(nèi)容,然后找到刪除的時間點(diǎn):

    # at 131708213
    #210610 11:27:01 server id 1  end_log_pos 131708311 CRC32 0x0fc755e2     Table_map: `loongwind_base`.`xxxx` mapped to number 139
    # at 131708311
    #210610 11:27:01 server id 1  end_log_pos 131708411 CRC32 0xa91616b9     Write_rows: table id 139 flags: STMT_END_F
    
    BINLOG '
    BffBYBMBAAAAYgAAAJe12QcAAIsAAAAAAAEADmR4bWhfYmFzZV9oenN5ABpkeF9zeV9hc3NldHNf
    ZXh0ZW5kc19jb3B5MQAICAgIDwgSCBIEAAgAAPgBAQACA/z/AOJVxw8=
    BffBYB4BAAAAZAAAAPu12QcAAIsAAAAAAAMAAgAI/wDRAwAAm1M8AUIAAADRUjwBCgAAAFYL5gAM
    AOWFrOWuieacuuWFs7EBAADbwZkAmama6E+xAQAA28GZAJmpmuhPuRYWqQ==
    '/*!*/;

    然后確定上次備份的時間點(diǎn),如果通過日志找不到上次備份的時間點(diǎn)可以填一個你記憶中確定小于上次備份的時間點(diǎn)

    2.2、使用 position 范圍

    使用如下命令查看日志 event 的 position

    mysql -uroot -p'password' -e "show binlog events in 'binlog.000002'"|grep -i 'DROP TABLE'

    執(zhí)行結(jié)果如下:

    binlog.000002    820474948    Query    1    820475111    use `loongwind_base`; DROP TABLE IF EXISTS `undo_log` /* generated by server */ /* xid=11790691 */

    即刪除的 position 為 820474948

    還是通過上述命令,替換關(guān)鍵字查找到上次備份的 position 點(diǎn)

    3、恢復(fù)

    3.1 通過時間恢復(fù)

    mysqlbinlog --no-defaults --database=loongwind_base --start-datetime="2021-06-07 09:00:00" --stop-datetime="2021-06-10 16:37:58" binlog.000005 | mysql -uroot -p'password' -s -N -f -D loongwind_base

    其中 dxmh_base_hzsy 是數(shù)據(jù)庫名稱

    3.2 通過 position 恢復(fù)

    mysqlbinlog  --start-position=1178  --stop-position=2751 -d dxmh-sy binlog.000002|mysql -uroot -p'password' -s -N -f -D loongwind_base
    loongwind_base 為數(shù)據(jù)庫名稱

    如果實(shí)在找不到開始時間或者開始 position 也可以不寫 --start-datetime 或 --start-position ,這樣就是用這個日志文件的開始一直恢復(fù)到結(jié)束,為了防止與已有數(shù)據(jù)的沖突,需要加上 -f 即 force 跳過錯誤繼續(xù)往下執(zhí)行。

    關(guān)于“怎么通過日志文件恢復(fù)MySQL數(shù)據(jù)”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識,可以關(guān)注億速云行業(yè)資訊頻道,小編每天都會為大家更新不同的知識點(diǎn)。

    向AI問一下細(xì)節(jié)

    免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

    AI