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

一步步教你如何使用mysql?binlog恢復數(shù)據(jù)

 更新時間:2023年04月04日 09:05:21   作者:ikt4435  
Binlog日志即binary?log,是二進制日志文件,有兩個作用,一個是增量備份,另一個是主從復制,下面這篇文章主要給大家介紹了關于如何使用mysql?binlog?恢復數(shù)據(jù)的相關資料,需要的朋友可以參考下

如果想通過 mysql 的 binlog 恢復數(shù)據(jù),首先要開啟 binlog 。這里搭建一個測試的環(huán)境,了解一下 mysql binlog 是如何恢復數(shù)據(jù)庫的。原理比較簡單,binlog 會存儲mysql中變化的數(shù)據(jù),比如你創(chuàng)建了一個數(shù)據(jù)庫,寫入了一些數(shù)據(jù),這些都會存儲在 mysql 的 binlog 中。

需要恢復的時候就找到,兩個位置,一個起始位置,一個結束的位置。結束的位置,一半是數(shù)據(jù)被破壞或者刪除前的位置。mysql 8 默認已經(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)開啟, 同時可以看到存儲的位置在 /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

可以看到有好幾個 binlog 日志文件, 因為這里是測試的數(shù)據(jù)庫(有歷史信息,之前的數(shù)據(jù),沒什么用),為了方便測試,直接進行重置操作。(刪除了全部binlog文件) ,如果是生成環(huán)境 ,謹慎操作,數(shù)據(jù)無價。

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)生一個新的 binlog 文件。

可以查看一下這個文件的內容

$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 /*!*/;
...

這個時候,我們添加一些數(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

這個時候,不小心刪除了,數(shù)據(jù)庫 test_liuhaolin_com

mysql> drop database test_liuhaolin_com;
Query OK, 1 row affected (0.09 sec)

現(xiàn)在就需要解決一個實際問題,怎么恢復這個數(shù)據(jù)庫

首先為了防止干擾,執(zhí)行 flush logs ,產(chǎn)生一個新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)

恢復數(shù)據(jù),首先要找到數(shù)據(jù)在哪里被刪除了。

mysqlbinlog binlog.000001 | grep -n  "drop database"
113:drop database test_liuhaolin_com

可以看到在 113 行的地方有個 刪除語句。終可以找到兩個地方

  1. 數(shù)據(jù)需要恢復的起始位置
  2. 數(shù)據(jù)需要恢復的結束位置

這里起始的位置就找 創(chuàng)建數(shù)據(jù)庫的位置,結束的位置就找 刪除數(shù)據(jù)庫的位置。

mysqlbinlog --set-charset=utf8  binlog.000001 > tmp.sql

可以在文件 tmp.sql 中知道 開始和結束位置

binlog

可以看到開始的地方是 233

binlog

可以看到結束的位置在 1371 ,所以執(zhí)行一下數(shù)據(jù)的恢復。

mysqlbinlog -v binlog.000001 --start-position=233 --stop-position=1371 | mysql

作為驗證,執(zhí)行前可以,看下 數(shù)據(jù)庫是否存在。

mysql> use test_liuhaolin_com;
ERROR 1049 (42000): Unknown database 'test_liuhaolin_com'

# 執(zhí)行恢復操作
mysqlbinlog -v  binlog.000001  --start-position=233  --stop-position=1371 | mysql 

# 再次檢查,可以發(fā)現(xiàn)數(shù)據(jù)已經(jīng)恢復
mysql>
mysql> use test_liuhaolin_com;
Database changed

總結

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

相關文章

  • Mysql之索引的數(shù)據(jù)結構詳解

    Mysql之索引的數(shù)據(jù)結構詳解

    索引是存儲引擎用于快速找到數(shù)據(jù)記錄的一種數(shù)據(jù)結構,類似于教科書的目錄部分,在MySQL中,索引可以加速數(shù)據(jù)查找,減少磁盤I/O的次數(shù),提高查詢速率,但是,創(chuàng)建和維護索引需要耗費時間,并且索引需要占磁盤空間,在InnoDB中,索引的實現(xiàn)基于B+樹結構
    2024-12-12
  • MySQL大小寫敏感導致的問題分析

    MySQL大小寫敏感導致的問題分析

    在本篇內容里小編給大家整理了關于MySQL大小寫敏感導致的問題的詳細分析,有興趣的朋友們可以學習參考下。
    2019-06-06
  • MYSQL存儲過程即常用邏輯知識點總結

    MYSQL存儲過程即常用邏輯知識點總結

    在本篇文章里小編給大家整理的是關于MYSQL存儲過程即常用邏輯知識點,有需要的朋友們可以學習下。
    2019-08-08
  • MySQL進階SELECT語法篇

    MySQL進階SELECT語法篇

    從這個基本語法可以看出,最簡單的SELECT語句是SELECT select_list,實際上利用這個最簡單的SELECT語句,你也可以完成許多你期待的功能,首先你能利用它進行MySQL所支持的任何運算,例如:SELECT 1+1,它將返回2;其次,你也能利用它給變量賦值,而在PHP中,運用SELECT語句的這種功能,你就可以自由地運用MySQL的函數(shù)為PHP程序進行各種運算,并賦值給變量。在很多的時候,你會發(fā)現(xiàn)MySQL擁有許多比PHP更為功能強大的函數(shù)。
    2008-04-04
  • MySQL如何修改賬號的IP限制條件詳解

    MySQL如何修改賬號的IP限制條件詳解

    這篇文章主要給大家介紹了關于MySQL如何修改賬號的IP限制條件的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧。
    2017-08-08
  • 阿里云centos7中安裝MySQL8.0.13的方法步驟

    阿里云centos7中安裝MySQL8.0.13的方法步驟

    這篇文章主要介紹了阿里云centos7中安裝MySQL8.0.13的方法步驟,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-07-07
  • 通過sysbench工具實現(xiàn)MySQL數(shù)據(jù)庫的性能測試的方法

    通過sysbench工具實現(xiàn)MySQL數(shù)據(jù)庫的性能測試的方法

    sysbench是一款壓力測試工具,可以測試系統(tǒng)的硬件性能,也可以用來對數(shù)據(jù)庫進行基準測試。這篇文章主要介紹了通過sysbench工具實現(xiàn)MySQL數(shù)據(jù)庫的性能測試 ,需要的朋友可以參考下
    2019-07-07
  • MySQL學習之數(shù)據(jù)庫備份詳解

    MySQL學習之數(shù)據(jù)庫備份詳解

    本篇文章主要介紹了MySQL中的 數(shù)據(jù)庫備份詳解,有需要的朋友可以借鑒參考下,希望可以有所幫助,祝大家多多進步,早日升職加薪
    2021-09-09
  • win2003 安裝2個mysql實例做主從同步服務配置

    win2003 安裝2個mysql實例做主從同步服務配置

    注意的就是路徑的正確書寫。然后在my.ini的配置中,server_id必須保持唯一性。port避免使用3306,服務名稱和mysql5.1不一樣即可。
    2011-05-05
  • MySQL INNER JOIN 的底層實現(xiàn)原理分析

    MySQL INNER JOIN 的底層實現(xiàn)原理分析

    這篇文章主要介紹了MySQL INNER JOIN 的底層實現(xiàn)原理,INNER JOIN的工作分為篩選和連接兩個步驟,連接時可以使用多種算法,通過本文,我們深入了解了MySQL中INNER JOIN的底層實現(xiàn)原理,需要的朋友可以參考下
    2023-06-06

最新評論