一步步教你如何使用mysql?binlog恢復(fù)數(shù)據(jù)
如果想通過 mysql 的 binlog 恢復(fù)數(shù)據(jù),首先要開啟 binlog 。這里搭建一個(gè)測試的環(huán)境,了解一下 mysql binlog 是如何恢復(fù)數(shù)據(jù)庫的。原理比較簡單,binlog 會(huì)存儲(chǔ)mysql中變化的數(shù)據(jù),比如你創(chuàng)建了一個(gè)數(shù)據(jù)庫,寫入了一些數(shù)據(jù),這些都會(huì)存儲(chǔ)在 mysql 的 binlog 中。
需要恢復(fù)的時(shí)候就找到,兩個(gè)位置,一個(gè)起始位置,一個(gè)結(jié)束的位置。結(jié)束的位置,一半是數(shù)據(jù)被破壞或者刪除前的位置。mysql 8 默認(rèn)已經(jīng)開啟了 binlog
mysql> show variables like '%log_bin%'; +---------------------------------+--------------------------+ | Variable_name | Value | +---------------------------------+--------------------------+ | log_bin | ON | | log_bin_basename | /data/mysql/binlog | | log_bin_index | /data/mysql/binlog.index | | log_bin_trust_function_creators | OFF | | log_bin_use_v1_row_events | OFF | | sql_log_bin | ON | +---------------------------------+--------------------------+
可以看到 log_bin 已經(jīng)開啟, 同時(shí)可以看到存儲(chǔ)的位置在 /daba/mysql 目錄 , 前綴是 binlog
ls /data/mysql/binlog.* /data/mysql/binlog.000143 /data/mysql/binlog.000144 /data/mysql/binlog.000145 /data/mysql/binlog.000146 /data/mysql/binlog.index
可以看到有好幾個(gè) binlog 日志文件, 因?yàn)檫@里是測試的數(shù)據(jù)庫(有歷史信息,之前的數(shù)據(jù),沒什么用),為了方便測試,直接進(jìn)行重置操作。(刪除了全部binlog文件) ,如果是生成環(huán)境 ,謹(jǐn)慎操作,數(shù)據(jù)無價(jià)。
show master logs; +---------------+-----------+-----------+ | Log_name | File_size | Encrypted | +---------------+-----------+-----------+ | binlog.000143 | 156 | No | | binlog.000144 | 200 | No | | binlog.000145 | 156 | No | | binlog.000146 | 156 | No | +---------------+-----------+-----------+ 4 rows in set (0.01 sec) mysql> reset master; Query OK, 0 rows affected (0.02 sec) mysql> show master logs; +---------------+-----------+-----------+ | Log_name | File_size | Encrypted | +---------------+-----------+-----------+ | binlog.000001 | 156 | No | +---------------+-----------+-----------+ 1 row in set (0.00 sec) ls /data/mysql/binlog.* /data/mysql/binlog.000001 /data/mysql/binlog.index
執(zhí)行重置(reset master)后 ,可以看到之前的 binlog 文件已經(jīng)被刪除了,產(chǎn)生一個(gè)新的 binlog 文件。
可以查看一下這個(gè)文件的內(nèi)容
$mysqlbinlog binlog.000001 # The proper term is pseudo_replica_mode, but we use this compatibility alias # to make the statement usable on server versions 8.0.24 and older. /*!50530 SET @@SESSION.PSEUDO_SLAVE_MODE=1*/; /*!50003 SET @OLD_COMPLETION_TYPE=@@COMPLETION_TYPE,COMPLETION_TYPE=0*/; DELIMITER /*!*/; ...
這個(gè)時(shí)候,我們添加一些數(shù)據(jù)
mysql <<EOT create database test_liuhaolin_com; select now(); EOT mysql <<EOT use test_liuhaolin_com; create table if not exists test( \`id\` int unsigned not null auto_increment primary key, \`key\` varchar(100), \`val\` varchar(255) ) engine=myisam charset=utf8mb4; EOT mysql <<EOT use test_liuhaolin_com; insert into test values ('1','website', 'https://www.liuhaolin.com'); EOT
這個(gè)時(shí)候,不小心刪除了,數(shù)據(jù)庫 test_liuhaolin_com
mysql> drop database test_liuhaolin_com; Query OK, 1 row affected (0.09 sec)
現(xiàn)在就需要解決一個(gè)實(shí)際問題,怎么恢復(fù)這個(gè)數(shù)據(jù)庫
首先為了防止干擾,執(zhí)行 flush logs ,產(chǎn)生一個(gè)新binlog 文件。
mysql> show master logs; +---------------+-----------+-----------+ | Log_name | File_size | Encrypted | +---------------+-----------+-----------+ | binlog.000001 | 1594 | No | +---------------+-----------+-----------+ 1 row in set (0.00 sec) mysql> show master status; +---------------+----------+--------------+------------------+-------------------+ | File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set | +---------------+----------+--------------+------------------+-------------------+ | binlog.000001 | 1594 | | | | +---------------+----------+--------------+------------------+-------------------+ 1 row in set (0.00 sec) mysql> flush logs; Query OK, 0 rows affected (0.08 sec) mysql> show master status; +---------------+----------+--------------+------------------+-------------------+ | File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set | +---------------+----------+--------------+------------------+-------------------+ | binlog.000002 | 156 | | | | +---------------+----------+--------------+------------------+-------------------+ 1 row in set (0.00 sec)
恢復(fù)數(shù)據(jù),首先要找到數(shù)據(jù)在哪里被刪除了。
mysqlbinlog binlog.000001 | grep -n "drop database" 113:drop database test_liuhaolin_com
可以看到在 113 行的地方有個(gè) 刪除語句。終可以找到兩個(gè)地方
- 數(shù)據(jù)需要恢復(fù)的起始位置
- 數(shù)據(jù)需要恢復(fù)的結(jié)束位置
這里起始的位置就找 創(chuàng)建數(shù)據(jù)庫的位置,結(jié)束的位置就找 刪除數(shù)據(jù)庫的位置。
mysqlbinlog --set-charset=utf8 binlog.000001 > tmp.sql
可以在文件 tmp.sql 中知道 開始和結(jié)束位置
binlog
可以看到開始的地方是 233
binlog
可以看到結(jié)束的位置在 1371 ,所以執(zhí)行一下數(shù)據(jù)的恢復(fù)。
mysqlbinlog -v binlog.000001 --start-position=233 --stop-position=1371 | mysql
作為驗(yàn)證,執(zhí)行前可以,看下 數(shù)據(jù)庫是否存在。
mysql> use test_liuhaolin_com; ERROR 1049 (42000): Unknown database 'test_liuhaolin_com' # 執(zhí)行恢復(fù)操作 mysqlbinlog -v binlog.000001 --start-position=233 --stop-position=1371 | mysql # 再次檢查,可以發(fā)現(xiàn)數(shù)據(jù)已經(jīng)恢復(fù) mysql> mysql> use test_liuhaolin_com; Database changed
總結(jié)
到此這篇關(guān)于如何使用mysql binlog 恢復(fù)數(shù)據(jù)的文章就介紹到這了,更多相關(guān)mysql binlog恢復(fù)數(shù)據(jù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- MySQL通過binlog實(shí)現(xiàn)恢復(fù)數(shù)據(jù)
- Python MySQL如何通過Binlog獲取變更記錄恢復(fù)數(shù)據(jù)
- MySQL通過日志恢復(fù)數(shù)據(jù)的操作步驟
- MySQL通過ibd文件恢復(fù)數(shù)據(jù)的操作過程
- MySQL開啟配置binlog及通過binlog恢復(fù)數(shù)據(jù)步驟詳析
- mysql binlog如何恢復(fù)數(shù)據(jù)到某一時(shí)刻
- MySQL誤刪后使用binlog恢復(fù)數(shù)據(jù)的實(shí)現(xiàn)方法
- mysql數(shù)據(jù)損壞,如何通過ibd和frm文件批量恢復(fù)數(shù)據(jù)庫數(shù)據(jù)
- Mysql如何通過ibd文件恢復(fù)數(shù)據(jù)
- mysql如何根據(jù).frm和.ibd文件恢復(fù)數(shù)據(jù)表
- MySql恢復(fù)數(shù)據(jù)方法梳理講解
- Mysql通過ibd文件恢復(fù)數(shù)據(jù)的詳細(xì)步驟
- MySQL數(shù)據(jù)庫通過Binlog恢復(fù)數(shù)據(jù)的詳細(xì)步驟
- Mysql如何通過binlog日志恢復(fù)數(shù)據(jù)詳解
- mysql5.7使用binlog 恢復(fù)數(shù)據(jù)的方法
- MySQL通過binlog恢復(fù)數(shù)據(jù)
- mysql8.0無備份通過idb文件恢復(fù)數(shù)據(jù)的方法、idb文件修復(fù)和tablespace?id不一致處理
相關(guān)文章
Mysql之索引的數(shù)據(jù)結(jié)構(gòu)詳解
索引是存儲(chǔ)引擎用于快速找到數(shù)據(jù)記錄的一種數(shù)據(jù)結(jié)構(gòu),類似于教科書的目錄部分,在MySQL中,索引可以加速數(shù)據(jù)查找,減少磁盤I/O的次數(shù),提高查詢速率,但是,創(chuàng)建和維護(hù)索引需要耗費(fèi)時(shí)間,并且索引需要占磁盤空間,在InnoDB中,索引的實(shí)現(xiàn)基于B+樹結(jié)構(gòu)2024-12-12MYSQL存儲(chǔ)過程即常用邏輯知識(shí)點(diǎn)總結(jié)
在本篇文章里小編給大家整理的是關(guān)于MYSQL存儲(chǔ)過程即常用邏輯知識(shí)點(diǎn),有需要的朋友們可以學(xué)習(xí)下。2019-08-08- 從這個(gè)基本語法可以看出,最簡單的SELECT語句是SELECT select_list,實(shí)際上利用這個(gè)最簡單的SELECT語句,你也可以完成許多你期待的功能,首先你能利用它進(jìn)行MySQL所支持的任何運(yùn)算,例如:SELECT 1+1,它將返回2;其次,你也能利用它給變量賦值,而在PHP中,運(yùn)用SELECT語句的這種功能,你就可以自由地運(yùn)用MySQL的函數(shù)為PHP程序進(jìn)行各種運(yùn)算,并賦值給變量。在很多的時(shí)候,你會(huì)發(fā)現(xiàn)MySQL擁有許多比PHP更為功能強(qiáng)大的函數(shù)。2008-04-04
通過sysbench工具實(shí)現(xiàn)MySQL數(shù)據(jù)庫的性能測試的方法
sysbench是一款壓力測試工具,可以測試系統(tǒng)的硬件性能,也可以用來對(duì)數(shù)據(jù)庫進(jìn)行基準(zhǔn)測試。這篇文章主要介紹了通過sysbench工具實(shí)現(xiàn)MySQL數(shù)據(jù)庫的性能測試 ,需要的朋友可以參考下2019-07-07MySQL學(xué)習(xí)之?dāng)?shù)據(jù)庫備份詳解
本篇文章主要介紹了MySQL中的 數(shù)據(jù)庫備份詳解,有需要的朋友可以借鑒參考下,希望可以有所幫助,祝大家多多進(jìn)步,早日升職加薪2021-09-09win2003 安裝2個(gè)mysql實(shí)例做主從同步服務(wù)配置
注意的就是路徑的正確書寫。然后在my.ini的配置中,server_id必須保持唯一性。port避免使用3306,服務(wù)名稱和mysql5.1不一樣即可。2011-05-05MySQL INNER JOIN 的底層實(shí)現(xiàn)原理分析
這篇文章主要介紹了MySQL INNER JOIN 的底層實(shí)現(xiàn)原理,INNER JOIN的工作分為篩選和連接兩個(gè)步驟,連接時(shí)可以使用多種算法,通過本文,我們深入了解了MySQL中INNER JOIN的底層實(shí)現(xiàn)原理,需要的朋友可以參考下2023-06-06