目录

一、介绍

二、binlog模式

三、开启和查看binlog

1、开启binlog, 通过修改/etc/my.inf文件开启binlog

2、首先查看mysql是否开启binlog同步功能

3、查看mysql的binlog模式

4、binlog相关命令

四、使用mysqlbinlog恢复数据


一、介绍

二进制日志(binnary log)它记录了数据库上的所有改变,并以二进制的形式保存在磁盘中。

binlog是记录所有数据库表结构变更(例如CREATE、ALTER TABLE…)以及表数据修改(INSERT、UPDATE、DELETE…)的二进制日志。

binlog不会记录SELECT和SHOW这类操作,因为这类操作对数据本身并没有修改,但你可以通过查询通用日志来查看MySQL执行过的所有语句。

二、binlog模式

binlog有三种格式:ROW(行模式), Statement(语句模式-默认), Mixed(混合模式)

ROW(行模式):记录那条数据修改了,注意:记录的是这条记录的全部数据,即使只更新了一个字段,binlog里也会记录所有字段的数据

优点:他不记录sql语句的上下文信息,日志内容会非常清楚的记录每条数据详细的变更细节,即使只更新了一个字段,binlog里也会记录所有字段的数据。

缺点:binlog日志会非常大,mysql主从同步时,会产生大量磁盘IO

Statement(语句模式): 每一条会修改数据的sql都会记录在binlog中。

优点:不需要记录每一行的变化,减少了binlog日志量,节约了IO,提高性能。

缺点:由于记录的只是执行语句,为了这些语句能在slave上正确运行,因此还必须记录每条语句在执行的时候的一些相关信息,以保证所有语句能在slave得到和在master端执行时候相同 的结果。另外mysql 的复制,像一些特定函数功能,slave可与master上要保持一致会有很多相关问题。

Mixed(混合模式):在Mixed模式下,一般的语句修改使用statment格式保存binlog,如一些函数,statement无法完成主从复制的操作,则采用row格式保存binlog,MySQL会根据执行的每一条具体的sql语句来区分对待记录的日志形式,也就是在Statement和Row之间选择一种。

场景中如何选择binlog的模式:

1、 如果生产中使用MySQL的特殊功能相对少(存储过程、触发器、函数)。选择默认的语句模式,Statement Level。

2、 如果生产中使用MySQL的特殊功能较多的,可以选择Mixed模式。

3、 如果生产中使用MySQL的特殊功能较多,又希望数据最大化一致,此时最好Row level模式;但是要注意,该模式的binlog非常的“重”。

三、开启和查看binlog

1、开启binlog, 通过修改/etc/my.inf文件开启binlog

[mysqld] # 这一行必须有,否则会出错

#log_bin
server_id = 123 #配置mysql replication需要定义,不能和canal的slaveId重复

log-bin = mysql-bin #开启binlog

binlog-format = row #选择ROW模式

2、首先查看mysql是否开启binlog同步功能

show variables like '%log_bin%';


binlog功能已经开启,默认是关闭的,需要开启

3、查看mysql的binlog模式

show variables like 'binlog_format'


可以看到当前Mysql binlog模式为ROW

4、binlog相关命令

show binary logs    #获取binlog文件日志列表

show master status # 查看当前正在写入的binlog文件

show master logs # 查看master上的binlog文件

show binlog events #查看第一个binlog文件内容

show binlog events in  'mysql-bin.000002' # 查看指定binlog文件内容, 如:查看mysql-bin.000002文件内容

flush logs #刷新日志,产生一个新编号的binlog文件

reset master #清除所有的binlog日志

四、使用mysqlbinlog恢复数据

 · 恢复全部数据
/usr/bin/mysqlbinlog --no-defaults /var/lib/mysql/mysql-bin.000002 | mysql -uroot -p

 · 恢复恢复某数据库的数据
/usr/bin/mysqlbinlog --no-defaults --database=test /var/lib/mysql/mysql-bin.000002 | mysql -uroot -p

 · 恢复指定位置数据
/usr/bin/mysqlbinlog --no-defaults --start-position="204" --stop-position="556" /var/lib/mysql/mysql-bin.000002 | mysql -uroot -p

 · 恢复指定时间段数据
/usr/bin/mysqlbinlog --no-defaults /var/lib/mysql/mysql-bin.000002 --stop-date= "2022-04-19 12:00:00" --start-date= "2022-04-19 11:55:00" | mysql -uroot -p

 · 将数据导入sql文件中
/usr/bin/mysqlbinlog --no-defaults /var/lib/mysql/mysql-bin.000002  > /tmp/aa.sql

 · 将数据展示在屏幕上
/usr/bin/mysqlbinlog --no-defaults /var/lib/mysql/mysql-bin.000002  | more

bin-log日志详解和使用mysqlbinlog恢复数据相关推荐

  1. mysql slow log损坏_06 : mysql 的 binlog 日志 和slow慢日志 详解

    mysql 的 binlog 日志 和slow慢日志 详解 mysql一般常用的日志有三种: 1:error错误日志 2: binlog日志 3:slow日志 下面将详细解释这三种日志: 1.错误日志 ...

  2. MySQL管理之日志详解

    MySQL日志详解 错误日志 MySQL的错误信息是在data目录下的 错误日志本身所定义的内容本身是可以定义的 编辑配置文件,定义错误日志: log-error=/path/to/xx.err   ...

  3. JVM GC 日志详解

    本文采用的JDK版本: java version "1.8.0_144" Java(TM) SE Runtime Environment (build 1.8.0_144-b01) ...

  4. JVM从入门到精通(十一): CMS日志详解,G1日志详解,JVM常见参数总结;补充纤程知识

    CMS 日志格式分析 使用CMS:添加参数UserConcMarkSweepGC(CMS+ParNew) CMS常用参数 -XX:+UseConcMarkSweepGC -XX:ParallelCMS ...

  5. MySQL日志文件之错误日志和慢查询日志详解

    今天天气又开始变得很热了,虽然很热很浮躁,但是不能不学习,我在北京向各位问好.今天给大家分享一点关于数据库日志方面的东西,因为日志不仅讨厌而且还很重要,在开发中时常免不了与它的亲密接触,就在前几天公司 ...

  6. SpringBoot2.1.5(16)--- Spring Boot的日志详解

    SpringBoot2.1.5(16)--- Spring Boot的日志详解 市面上有许多的日志框架,比如 JUL( java.util.logging), JCL( Apache Commons ...

  7. GC日志详解[乐乐独记]

    GC日志详解[乐乐独记] 1.静态分析GC日志 1.1.Parallel GC日志 1.2.CMS GC日志 1.3.G1 GC日志 2.使用工具分析GC日志 10.辅助知识 10.1.元空间不足也会 ...

  8. git log 命令详解

    git log 命令详解 git log 命令用于查看提交历史: git log [options] [<file> <commit> <tag>...] 如果不加 ...

  9. Hadoop日志详解

    文章目录 1 Hadoop日志详解 2 Hadoop 系统服务输出的日志 2.1 修改Hadoop系统服务日志目录(包括NameNode.secondarynamenode.datanode.reso ...

最新文章

  1. 平方变换载波同步 matlab,matlab源码-costas载波同步环.docx
  2. Java 创建用户异常类、将异常一直向上抛、 throw和throws的区别
  3. Linux查看文件夹大小的相关命令
  4. 基于对象和面向对象编程范式辨析和主流编程语言中的应用
  5. 转 Celery 使用
  6. Bigo 实时计算平台建设实践
  7. 蓝图中实现人物移动2
  8. 用JSmooth制作java jar文件的可运行exe文件教程【图文】
  9. C#~异步编程再续~你必须要知道的ThreadPool里的throw
  10. 03-谷歌浏览器安装Sence
  11. 一次排查服务器端接口报500错误的经历
  12. LOJ2316「NOIP2017」逛公园
  13. java nlpir_1---------java调用NLPIR(ICTCLAS2016)实现分词功能
  14. Java开发16个经典面试问题
  15. DAO年终盘点:光环加身,道阻且长 |链捕手
  16. Android中的网络编程
  17. AAAI 2023 | 基于联合学习与用户传播行为的虚假新闻早期检测
  18. css3实现div hover阴影效果
  19. 嵌入式文件服务器,嵌入式文件服务器
  20. Controlling GC pauses with the GarbageFirst Collector

热门文章

  1. java 日期和时间格式化转换符操作
  2. HDMI设计3--HDMI 1.4/2.0 Transmitter Subsystem IP
  3. 捷联惯导系统学习5.2(递归最小二乘法 )
  4. Docker私有镜像仓库
  5. Android高仿iOS Messages聊天气泡
  6. html聊天效果,HTML5实现QQ聊天气泡效果
  7. html2canvas:页面转图像和pdf
  8. 信息架构、产品架构和业务架构
  9. iOS 如何根据错误的堆栈地址定位到代码?
  10. ffmpeg colorkey_options中的black对应的十六进制