当前位置: 首页 > news >正文

mysql-恢复数据(日志管理)

前言

在mysql中我们有时候会出现误删除,或者其他的问题,我们可以通过mysql的日志进行恢复

操作

我们可以在mysql里面定义一个错误日志,方便我们可以排查是因为什么原因来解决mysql无法启动问题

-------------------------------------------------------------------------------------------------------------------------------

1.错误日志

进入到配置文件

vim /etc/my.cnf

添加或者找到你的错误日志

log_error=/tmp/mysql3306.log                  这里的路径是我自己设置的每人的目录有可能不同,具体看自己

重启

systemctl restart mysqld

查看日志        -这里就可以看到你在启动过程中遇到的问题

---------------------------------------------------------------------------------------------------------------------------------

2.二进制日志(binlog)

作用

(1) 主从要依赖二进制日志
(2) 数据恢复时需要依赖于二进制日志

我们在配置文件里面进行添加这个一般没有启动

log_bin=/databinlog/mysql-bin                这个是我在数据库进行了增删改的操作二进制文件就会存放到这里,后面我们就可以通过二进制文件进行恢复

我们可以查看一个用cat命令是查看不到的需要用mysql自己的

查看二进制日志内容
mysqlbinlog mysql-bin.000001        #看语句级日志,不能看行数据                
mysqlbinlog --base64-output=decode-rows -vvv mysql-bin.000001   #使用解码的方式,可看行数据
mysqlbinlog -d event mysql-bin.000001     #摘要显示事件号码

这里的        mysql-bin000001是我自己的,每次数据库经过重启或者刷新这个值就会加一

刷新命令         flush log;

截取日志

在恢复数据的途中我们可以选择从哪里恢复到哪里

我们恢复找到#数字开头然后下面找到操作命令的行然后到结束行就可以恢复

命令

1.截取出来保存到/tmp/a.sql目录下

mysqlbinlog --start-position=233 --stop-position=801 mysql-bin.000001 >/tmp/a.sql

这里的意思就是从233行恢复到801行

2.关闭二进制文件记录 set_sql_log_bin=0;        (为了避免太多的日志,不关闭会在日志重新疾苦一遍执行日志)

3.把数据导入到mysql         source /tmp/a.sql 

4.开启二进制文件         set_sql_log_bin=1;                --1为开启 0为关闭

----------------------------------------------------------------------------------------------------------------

第二种恢复(GTID)

对于binlog中的每一个事务,都会生成一个GTID号码                -
DDL ,DCL 一个event就是一个事务,就会有一个GTID号.
DML语句来讲,begin到commit,是一个事务,就是一个GTI

查看gtid号

cat /usr/local/mysql/data/auto.cnf 
[auto]
server-uuid=e2e9b01e-9687-11eb-b577-000c29b0384b

或者这样也可以查看到

TID是一个:自增长的数据,从1开始
e2e9b01e-9687-11eb-b577-000c29b0384b:1-15

GTID的幂等性
如果拿有GTID的日志去恢复时,检查当前系统中是否有相同GTID号,有相同的就自动跳过
会影响到binlog恢复和主从复制.

GTID的开启和配置
vim /etc/my.cnf
gtid-mode=on
enforce-gtid-consistency=true                

 基于GTID,binlog恢复

(1) 截取日志mysqlbinlog --include-gtids='3b915642-87b4-11ef-ae7c-000c2937c73c:1-3' mysql-bin.000001 >/tmp/gtid.sql

cd /data/binlog                -这里还是上面你的日志存放位置

mysqlbinlog --skip-gtids --include-gtids='820f8917-d358-11ec-b243-000c29cbdce4:1-3' mysql-bin.000001 >/tmp/gtid.sql                        -这里红的需要看你自己的是多少来修改
--skip-gtids 作用:在导出时,忽略原有的gtid信息,恢复时生成最新的gtid信息

这个日志查看比上面会多一个,大家注意这个为分隔

恢复

set sql_log_bin=0;
source /tmp/gtid.sql
set sql_log_bin=1;
 

对此大家可以最后加一个整表备份,然后定时测试是否可以正常使用

http://www.lryc.cn/news/474515.html

相关文章:

  • 探索Unity:从游戏引擎到元宇宙体验,聚焦内容创作
  • 自动化测试类型与持续集成频率的关系
  • React 中组件通信的几种主要方式
  • mint-ui Picker 显示异常
  • 深入理解 MySQL 中的日志类型及其应用场景
  • 群控系统服务端开发模式-应用开发-上传配置功能开发
  • stm32——GPIO开发
  • layui 自定义验证单选框必填
  • Spring 设计模式之策略模式
  • 苹果开发 IOS 证书生成步骤
  • DDR2 SDRAM(五)初始化
  • Python工具箱系列(五十七)
  • 数据智能驱动金融策略优化:民锋智能分析技术的应用
  • 1009:带余除法
  • Jmeter实际应用
  • C++基础(11.AVL树的实现)
  • c# 抽象方法 虚函数 使用场景
  • 大数据安全方案 验证
  • 电脑软件:推荐一款免费且实用的电脑开关机小工具
  • php反序列化靶场随笔分析
  • 动态规划 - 编辑距离
  • 力扣——113. 路径总和
  • C02S04-Ubuntu基本使用
  • C语言 | Leetcode C语言题解之第525题连续数组
  • Qml-Transition的使用
  • Notepad++检索包含多个关键字的行
  • C语言:水仙花树,要求三位以上的N位整数每位的N次方等于数本身,全部输出出来
  • 金融贷款口子超市V2源码 Thinkphp开发的贷款和超市平台源码(亲测源码含安装视频教程)
  • redis的三种客户端
  • 边缘计算【智能+安全检测】系列教程--agx orin解决RTC时间问题