iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >mysql binlog相关知识点有哪些
  • 872
分享到

mysql binlog相关知识点有哪些

2024-04-02 19:04:59 872人浏览 八月长安
摘要

本篇内容主要讲解“Mysql binlog相关知识点有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“mysql binlog相关知识点有哪些”吧!

本篇内容主要讲解“Mysql binlog相关知识点有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习mysql binlog相关知识点有哪些”吧!

1.
- 逻辑日志,记录的是数据库内部的所有变动(sql语句  行的改变)
- server层日志,binlog不仅仅记录innodb的变动,也记录myisam存储引擎的变动。
- innodb redo 是存储引擎层,和binlog不是一层,redo只记录innodb的变化。
- binlog不记录 select show 等查询语句,记录dml ddl等数据库变动的语句.

2.binlog的作用
- 可以查看mysql变更
- mysql的复制架构(主从)
- mysql备份恢复(可以通过binlog进行数据的补齐或者回滚)

3.binlog的位置
log_bin = /home/mysql3306/mysql3306/mysql-bin
#binlog路径+binlog前缀名 如:mysql-bin.000001

4.相关参数简介
(1).log-bin
决定了msyql 的binlog的名字,生成的binlog名字为mysql-bin.000001

(2).binlog_fORMat
规定binlog的格式,binlog有三种格式statement,row以及mixed,默认使用默认使用statement,建议使用row格式

(3).expire_logs_days
过期时间 建议大家根据业务设置7D-30D

(4).binlog_do_db
此参数表示只记录指定数据库的二进制日志

(5).binlog_ignore_db
此参数表示不记录指定的数据库的二进制日志

(6).sync_binlog(binlog落盘策略)
0---每一秒刷一次磁盘
1---每次事务提交都刷一次磁盘
n---(100 200 500)每n次提交落盘一次
innodb_flush_log_at_trx_commit =1 
sync_binlog=1
双1配置,数据库的安全性是最高的,不会丢事务。

(7).binlog_checksum 为 {CRC32|NONE}
写binlog时,会将内容生成校验位,之后存储在binlog中。
默认情况下,服务器记录事件的长度以及事件本身,并使用它来验证事件是否正确写入。 也可以通过设置 binlog_checksum系统变量来使服务器为事件写入校验和。

(8).max_binlog_size
binlog文件的最大值,默认和最大是1GB,并不能严格限定二进制文件的大小

(9).max_binlog_cache_size
表示的是binlog 能够使用的最大cache 内存大小
当我们执行多语句事务的时候 所有session的使用的内存超过max_binlog_cache_size的值时
就会报错:“Multi-statement transaction required more than 'max_binlog_cache_size' bytes ofstorage”

(10).binlog_cache_size = 4M
线程级参数,不能设置太大

5.binlog格式
(1).statement
mysql> show variables like '%binlog_format%';
+---------------+-----------+
| Variable_name | Value     |
+---------------+-----------+
| binlog_format | STATEMENT |
+---------------+-----------+

执行语句:
insert into wwj.t1 values(2,'mxt2');
insert into wwj.t1 values(3,'mxt3');
insert into wwj.t1 values(4,'mxt4');

查看binlog

点击(此处)折叠或打开

  1. mysql> show binlog events;

  2. +------------------+-----+----------------+-----------+-------------+---------------------------------------+

  3. | Log_name         | Pos | Event_type     | Server_id | End_log_pos | Info                                  |

  4. +------------------+-----+----------------+-----------+-------------+---------------------------------------+

  5. | mysql-bin.000001 |   4 | Format_desc    |  12023307 |         123 | Server ver: 5.7.21-log, Binlog ver: 4 |

  6. | mysql-bin.000001 | 123 | Previous_gtids |  12023307 |         154 |                                       |

  7. | mysql-bin.000001 | 154 | Anonymous_Gtid |  12023307 |         219 | SET @@SESSION.GTID_NEXT= 'ANONYMOUS'  |

  8. | mysql-bin.000001 | 219 | Query          |  12023307 |         293 | BEGIN                                 |

  9. | mysql-bin.000001 | 293 | Query          |  12023307 |         398 | insert into wwj.t1 values(13,'mxt3')  |

  10. | mysql-bin.000001 | 398 | Xid            |  12023307 |         429 | COMMIT                  |

  11. | mysql-bin.000001 | 429 | Anonymous_Gtid |  12023307 |         494 | SET @@SESSION.GTID_NEXT= 'ANONYMOUS'  |

  12. | mysql-bin.000001 | 494 | Query          |  12023307 |         568 | BEGIN                                 |

  13. | mysql-bin.000001 | 568 | Query          |  12023307 |         673 | insert into wwj.t1 values(14,'mxt4')  |

  14. | mysql-bin.000001 | 673 | Xid            |  12023307 |         704 | COMMIT                  |

  15. +------------------+-----+----------------+-----------+-------------+---------------------------------------+

Log_name: binlog文件名
Pos:binlog的position点,写入binlog的日志的字节数,就是pos的大小,在每次新生成binlog的时候,pos点会重置,但是在一个binlog内部,这个pos是单调递增的。
xid:分布式事务ID,Innodb支持分布式事务,Innodb支持的单实例内部的,server层和存储引擎层的分布式事务,还有多节点分布式事务(ndb)
Server_id:实例server_id

解析binlog工具
/usr/local/mysql/bin/mysqlbinlog mysql-bin.000001 > /tmp/all.bin

点击(此处)折叠或打开

  1. # at 293

  2. #180325  4:14:20 server id 12023307  end_log_pos 398 CRC32 0xb9d2f949   Query   thread_id=14    exec_time=0     error_code=0

  3. SET TIMESTAMP=1521922460;

  4. insert into wwj.t1 values(13,'mxt3')

  5. ;

  6. # at 398

查看当前的binlog pos点的位置
mysql> show master status;
ERROR 2006 (HY000): MySQL Server has Gone away
No connection. Trying to reconnect...
Connection id:    15
Current database: *** NONE ***
+------------------+----------+--------------+------------------+-------------------+
| File             | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+------------------+----------+--------------+------------------+-------------------+
| mysql-bin.000001 |      704 |              |                  |                   |
+------------------+----------+--------------+------------------+-------------------+


应用binlog
/usr/local/mysql/bin/mysqlbinlog mysql-bin.000001 > /tmp/all.bin
mysql -uroot -proot -S /tmp/mysql3306.sock < /tmp/all.bin
mysql > source /tmp/all.bin

应用binlog需要注意的事项
如果应用多个binlog
错误做法
mysqlbinlog mysql-bin.000001 | mysql -S -u -p
mysqlbinlog mysql-bin.000002 | mysql -S -u -p
正确做法
mysqlbinlog mysql-bin.000001 mysql-bin.000002 | mysql -S -u -p
或者
mysqlbinlog mysql-bin.000001 mysql-bin.000002 > /tmp/all.bin
mysql -S -u -p < /tmp/all.bin


(2).row
mysql> show variables like "binlog_format";
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| binlog_format | ROW   |
+---------------+-------+

row格式binlog:row格式binlog记录的是mysql的行的改变前后的数据
比如在stament格式中,update数据,记录的是update语句
而且row格式中,记录的行的改变的前后,如果update1000数据,记录一千行的数据改变

mysqlbinlog -v  mysql-bin.000001 > /tmp/all.bin  增加伪sql
mysqlbinlog -vv  mysql-bin.000001 > /tmp/all.bin  增加数据类型

点击(此处)折叠或打开

  1. # at 334

  2. #180325  5:51:04 server id 12023307  end_log_pos 458 CRC32 0x1be59376   Delete_rows: table id 108 flags: STMT_END_F


  3. BINLOG '

  4. SMi2WhMLdrcALwAAAE4BAAAAAGwAAAAAAAEAA3D3agACdDEAAgMPArQAAsKvIYM=

  5. SMi2WiALdrcAfAAAAMoBAAAAAGwAAAAAAAEAAgAC//wBAAAAA3d3avwCAAAABG14dDL8AwAAAARt

  6. eHQz/AQAAAAEbXh0NPwFAAAABG14dDL8BgAAAARteHQz/AcAAAAEbXh0NPwNAAAABG14dDP8DgAA

  7. AARteHQ0dpPlGw==

  8. ';

  9. ### DELETE FROM `wwj`.`t1`

  10. ### WHERE

  11. ###   @1=1

  12. ###   @2='wwj'

  13. ### DELETE FROM `wwj`.`t1`

  14. ### WHERE

  15. ###   @1=2

  16. ###   @2='mxt2'

  17. ### DELETE FROM `wwj`.`t1`

  18. ### WHERE

  19. ###   @1=3

  20. ###   @2='mxt3'

  21. ### DELETE FROM `wwj`.`t1`

  22. ### WHERE

  23. ###   @1=4

  24. ###   @2='mxt4'

  25. ### DELETE FROM `wwj`.`t1`

  26. ### WHERE

  27. ###   @1=5

  28. ###   @2='mxt2'

  29. ### DELETE FROM `wwj`.`t1`

  30. ### WHERE

  31. ###   @1=6

  32. ###   @2='mxt3'

  33. ### DELETE FROM `wwj`.`t1`

  34. ### WHERE

  35. ###   @1=7

  36. ###   @2='mxt4'

  37. ### DELETE FROM `wwj`.`t1`

  38. ### WHERE

  39. ###   @1=13

  40. ###   @2='mxt3'

  41. ### DELETE FROM `wwj`.`t1`

  42. ### WHERE

  43. ###   @1=14

  44. ###   @2='mxt4'

  45. # at 458


其他解析方法
解析不带行数据
/usr/local/mysql/bin/mysqlbinlog --base64-output=DECODE-ROWS -vv mysql-bin.000001
如果binlog解析出来需要恢复到数据库,那么需要注意不要加--base64-output=DECODE-ROWS。
/usr/local/mysql/bin/mysqlbinlog
start-datetime  开始时间
stop-datetime   停止时间
/usr/local/mysql/bin/mysqlbinlog --start-datetime="2017-04-20 9:00:00" --stop-datetime="2017-07-20 18:00:00"/home/mysql3306/mysql3306/mysql-bin.000001 > /tmp/mysql_binlog.sql
start-position  开始时间的position
stop-position   停止时间的position

row格式优点:
-记录行改变,而不是SQL,能最大限度保证数据安全性
-row格式可以用于闪回(恢复数据)
在线上的环境中,推荐使用row格式的binlog
-row格式update delete会对磁盘 网络造成一个比较大的压力


(3).mixed
一般情况下使用statment格式,在遇到特殊情况(造成主从不一致)改成使用row格式记录。
mixed格式在旧版本bug比较多
不推荐使用

6.清理binlog
 reset master; //删除master的binlog,线上不要使用
 purge master logs before '2012-03-30 17:20:00'; //删除指定日期以前的日志索引中binlog日志文件
 purge master logs to 'binlog.000002'; //删除指定日志文件的日志索引中binlog日志文件

如果想直接删除binlog
rm binlog.000002 
(不要删除当前正在使用的binlog,也就是编号最大的binlog)
[root@namenode mysql3306]# cat mysql-bin.index    不会自动更新
/home/mysql3306/mysql3306/mysql-bin.000001
/home/mysql3306/mysql3306/mysql-bin.000002
主从复制如果删掉了,容易从库报错(保证从库不再同步该binlog的数据)

7.binlog和redo的区别
- redo 物理逻辑日志 物理:数据页 逻辑: 数据页的改变
  binlog 是逻辑日志 记录的SQL或者是行改变
- redo是innodb存储引擎层
   binlog是server层
- redo时时刻刻都在写入文件
   binlog是 提交事务的写入(具体写入策略跟具体参数有关)

到此,相信大家对“mysql binlog相关知识点有哪些”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

您可能感兴趣的文档:

--结束END--

本文标题: mysql binlog相关知识点有哪些

本文链接: https://www.lsjlt.com/news/65330.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • mysql binlog相关知识点有哪些
    本篇内容主要讲解“mysql binlog相关知识点有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“mysql binlog相关知识点有哪些”吧! ...
    99+
    2024-04-02
  • MySQL相关知识点有哪些
    这篇文章主要介绍了MySQL相关知识点有哪些,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。 1、数据库架构1.1...
    99+
    2024-04-02
  • HashMap相关知识点有哪些
    本篇内容介绍了“HashMap相关知识点有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!HashMap 和 HashSet 是 Java...
    99+
    2023-06-17
  • Baseline相关知识点有哪些
    本篇内容主要讲解“Baseline相关知识点有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Baseline相关知识点有哪些”吧! 在 Oracle Da...
    99+
    2024-04-02
  • CSS相关知识点有哪些
    本篇内容介绍了“CSS相关知识点有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!  1、CSS选择器 ...
    99+
    2024-04-02
  • Git相关知识点有哪些
    这篇文章主要讲解了“Git相关知识点有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Git相关知识点有哪些”吧!一、Git工作流程以上包括一些简单而常用...
    99+
    2024-04-02
  • YARN相关知识点有哪些
    本篇内容介绍了“YARN相关知识点有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!YARN产生背景为什么会产生YRAN?这个与MapRe...
    99+
    2023-06-19
  • MySQL数据库相关知识点有哪些
    这篇文章给大家分享的是有关MySQL数据库相关知识点有哪些的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。一、数据库概要数据库(Database)是存储与管理数据的软件系统,就像一...
    99+
    2024-04-02
  • MySQL索引的相关知识点有哪些
    本篇内容介绍了“MySQL索引的相关知识点有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!索引介绍索引...
    99+
    2024-04-02
  • library cache相关知识点有哪些
    library cache相关知识点有哪些,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。共享游标Sql首次解析后会生成父游标和1个子游标(...
    99+
    2024-04-02
  • JVM相关的知识点有哪些
    这篇文章主要讲解了“JVM相关的知识点有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JVM相关的知识点有哪些”吧!JVM作为java运行的基础,很难相...
    99+
    2024-04-02
  • synchronized的相关知识点有哪些
    这篇文章主要讲解了“synchronized的相关知识点有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“synchronized的相关知识点有哪些”吧!...
    99+
    2024-04-02
  • 有哪些Java的相关知识点
    这篇文章主要介绍“有哪些Java的相关知识点”,在日常操作中,相信很多人在有哪些Java的相关知识点问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”有哪些Java的相关知识点”的疑惑有所帮助!接下来,请跟着小编...
    99+
    2023-06-16
  • Git的相关知识点有哪些
    这篇文章主要介绍“Git的相关知识点有哪些”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Git的相关知识点有哪些”文章能帮助大家解决问题。分支和合并Git 跟其他版本控制系统***的优势就在于其高级...
    99+
    2023-06-17
  • KeyDB的相关知识点有哪些
    今天小编给大家分享一下KeyDB的相关知识点有哪些的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。线程模型KeyDB将redi...
    99+
    2023-06-19
  • java Shiro相关知识点有哪些
    这篇文章主要介绍了java Shiro相关知识点有哪些的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇java Shiro相关知识点有哪些文章都会有所收获,下面我们一起来看看吧。1.权限的管理1.1 什么是权限管...
    99+
    2023-07-06
  • React的相关知识点有哪些
    这篇文章主要介绍“React的相关知识点有哪些”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“React的相关知识点有哪些”文章能帮助大家解决问题。React与传统MVC的关系轻量级的视图层库!A J...
    99+
    2023-06-03
  • js函数相关知识点有哪些
    这篇文章将为大家详细讲解有关js函数相关知识点有哪些,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。在js种函数实际上是对象,每个函数都是Function类型的实例。和其他...
    99+
    2024-04-02
  • AMM与ASMM相关知识点有哪些
    这篇文章主要讲解了“AMM与ASMM相关知识点有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“AMM与ASMM相关知识点有哪些”吧!一、AMM相关知识:...
    99+
    2024-04-02
  • Java中Volatile相关知识点有哪些
    这篇文章主要介绍“Java中Volatile相关知识点有哪些”,在日常操作中,相信很多人在Java中Volatile相关知识点有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Java中Volatile相关...
    99+
    2023-06-16
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作