关于mysql binlog二进制

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
日志服务 SLS,月写入数据量 50GB 1个月
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 关于mysql binlog二进制

binlog

在mysql中,当发生数据变更时,都会将变更数据的语句,通过二进制形式,存储到binlog日志文件中.

通过binlog文件,你可以查看mysql一段时间内,对数据库的所有改动.

也可以通过binlog文件,进行数据恢复,以及集群同步.

binlog常用配置参数

\[binlog\]
log\_bin = mysql-bin # {on | off | base\_name}指定是否启用记录二进制日志或者指定一个日志路径
sql\_log\_bin = on # { on | off }    指定是否启用记录二进制日志
expire\_logs\_days=7  #  指定自动删除二进制日志的时间,即日志过期时间
log\_bin\_index= /usr/local/mysql/mysql-bin.index    # 指定mysql-bin.index文件的路径
binlog_format = mixed # { mixed | row | statement }    指定二进制日志基于什么模式记录
max\_binlog\_size = 100M #   指定二进制日志文件最大值
binlog\_cache\_size = 4M #   指定事务日志缓存区大小
max\_binlog\_cache_size= 64M #   指定二进制日志缓存最大大小
sync_binlog = 0  # { 0 | n }   指定写缓冲多少次,刷一次盘

binlog常见命令

数据库sql命令

mysql>  show master logs;  # 查看日志文件列表
+------------------+-----------+
| Log\_name         | File\_size |
+------------------+-----------+
| mysql-bin.000009 |       143 |
| mysql-bin.000010 |       143 |
| mysql-bin.000011 |    646950 |
| mysql-bin.000012 |       120 |
+------------------+-----------+
4 rows in set (0.01 sec)
mysql> show master status; # 查看最后(最新)一个binlog日志的编号名称,及其最后一个操作事件pos结束点(Position)值
+------------------+----------+--------------+------------------+-------------------+
| File             | Position | Binlog\_Do\_DB | Binlog\_Ignore\_DB | Executed\_Gtid\_Set |
+------------------+----------+--------------+------------------+-------------------+
| mysql-bin.000012 |      120 |              |                  |                   |
+------------------+----------+--------------+------------------+-------------------+
1 row in set (0.00 sec)
mysql> flush logs; #刷新日志文件,产生新编号的日志文件
Query OK, 0 rows affected (0.01 sec)
mysql>  reset master; # 清空所有binlog日志
Query OK, 0 rows affected (0.00 sec)

mysqlbinlog命令

首先,我们需要通过查看配置项的 log-bin配置和datadir 配置项,获取到binlog文件存储位置,在宝塔中,默认为"/www/server/data/mysql-bin****"文件

通过mysqlbinlog命令,即可查看具体日志信息:

我们先创建一个简单的表,来进行测试

CREATE TABLE \`test\`.\`test\` ( \`id\` INT NOT NULL AUTO_INCREMENT , \`name\`VARCHAR(32) NOT NULL , \`age\` INT(10) NOT NULL , \`sex\` TINYINT(1) NOT NULL ,PRIMARY KEY (\`id\`)) ENGINE = InnoDB;

创建新的数据

INSERT INTO \`test\` (\`id\`, \`name\`, \`age\`, \`sex\`) VALUES (NULL, '仙士可','11', '1'), (NULL, '宁成龙', '33', '1'), (NULL, '宁成龙22', '1', '12')

查看binlog文件

\[root@localhost data\]# /www/server/mysql/bin/mysqlbinlog mysql-bin.000015
/*!50530 SET @@SESSION.PSEUDO\_SLAVE\_MODE=1*/;
/*!40019 SET @@session.max\_insert\_delayed_threads=0*/;
/*!50003 SET @OLD\_COMPLETION\_TYPE=@@COMPLETION\_TYPE,COMPLETION\_TYPE=0*/;
DELIMITER /*!*/;
# at 4
#200415 21:39:32 server id 1  end\_log\_pos 120 CRC32 0x05fef589  Start: binlog v 4, server v 5.6.44-log created 200415 21:39:32 at startup
# Warning: this binlog is either in use or was not closed properly.
ROLLBACK/*!*/;
BINLOG '
lA6XXg8BAAAAdAAAAHgAAAABAAQANS42LjQ0LWxvZwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAACUDpdeEzgNAAgAEgAEBAQEEgAAXAAEGggAAAAICAgCAAAACgoKGRkAAYn1
/gU=
'/*!*/;
# at 120
#200417 22:19:10 server id 1  end\_log\_pos 383 CRC32 0x7f61e7b6  Query   thread\_id=26    exec\_time=0     error_code=0
use \`test\`/*!*/;
SET TIMESTAMP=1587133150/*!*/;
SET @@session.pseudo\_thread\_id=26/*!*/;
SET @@session.foreign\_key\_checks=1, @@session.sql\_auto\_is\_null=0, @@session.unique\_checks=1, @@session.autocommit=1/*!*/;
SET @@session.sql_mode=1342177280/*!*/;
SET @@session.auto\_increment\_increment=1, @@session.auto\_increment\_offset=1/*!*/;
/*!\\C utf8mb4 *//*!*/;
SET @@session.character\_set\_client=45,@@session.collation\_connection=224,@@session.collation\_server=45/*!*/;
SET @@session.lc\_time\_names=0/*!*/;
SET @@session.collation_database=DEFAULT/*!*/;
CREATE TABLE \`test\`.\`test\` ( \`id\` INT NOT NULL AUTO_INCREMENT ,  \`name\` VARCHAR(32) NOT NULL ,  \`age\` INT(10) NOT NULL ,  \`sex\` TINYINT(1) NOT NULL ,    PRIMARY KEY  (\`id\`)) ENGINE = InnoDB
/*!*/;
# at 383
#200417 22:20:26 server id 1  end\_log\_pos 462 CRC32 0xb0c717e0  Query   thread\_id=64    exec\_time=0     error_code=0
SET TIMESTAMP=1587133226/*!*/;
BEGIN
/*!*/;
# at 462
# at 494
#200417 22:20:26 server id 1  end\_log\_pos 494 CRC32 0x90b2c86f  Intvar
SET INSERT_ID=1/*!*/;
#200417 22:20:26 server id 1  end\_log\_pos 718 CRC32 0x1969fb9b  Query   thread\_id=64    exec\_time=0     error_code=0
SET TIMESTAMP=1587133226/*!*/;
INSERT INTO \`test\` (\`id\`, \`name\`, \`age\`, \`sex\`) VALUES (NULL, '仙士可','11', '1'), (NULL, '宁成龙', '33', '1'), (NULL, '宁成龙22', '1', '12')
/*!*/;
# at 718
#200417 22:20:26 server id 1  end\_log\_pos 749 CRC32 0x359c1fc1  Xid = 569
COMMIT/*!*/;
DELIMITER ;
# End of log file
ROLLBACK /* added by mysqlbinlog */;
/*!50003 SET COMPLETION\_TYPE=@OLD\_COMPLETION_TYPE*/;
/*!50530 SET @@SESSION.PSEUDO\_SLAVE\_MODE=0*/;
\[root@localhost data\]#

可以看到,binlog日志中记录了创建数据表,和insert数据的记录.

同时,mysqlbinlog命令还支持日志筛选等参数.

常用参数:
--start-datetime=datetime 从二进制日志中第1个日期时间等于或晚于datetime参量的事件开始读取。datetime值相对于运行mysqlbinlog的机器上的本地时区。该值格式应符合DATETIME或TIMESTAMP数据类型。
--stop-datetime=datetime 从二进制日志中第1个日期时间等于或晚于datetime参量的事件起停止读。关于datetime值的描述参见--start-datetime选项。该选项可以帮助及时恢复。
--start-position=N 从二进制日志中第1个位置等于N参量时的事件开始读。
--stop-position=N 从二进制日志中第1个位置等于和大于N参量时的事件起停止读。
--base64-output=DECODE-ROWS 会显示出row模式带来的sql变更
-d 与 --database 效果相同,指定一个数据库名称。
--offset=N,-o N 跳过前N个条目。

binlog模式

在上面我们讲到了,mysql发生数据变更后,才会将变更的语句,通过二进制形式存储,而通过存储语句的方式,mysql将其分为了3种方式.

行模式(row level)


binlog日志将会记录数据库中每一条的数据变更,例如当你delete 数据100万条时,会产生100万条记录,用于记录每一行数据的变更情况.

优点:此模式可以非常精确的记录每条记录的变更细节.不需要依赖sql的上下文关系,例如存储过程,触发器.

缺点:此模式会产生大量的日志内容.

语句模式(Statement Level)

mysql默认模式,和行模式不同的事,语句模式会直接记录mysql执行数据变更的语句,例如delete 100万数据,它只会记录该delete语句,如果需要调用binlog时,将会通过记录的这个语句,重新执行一遍delete.

混合模式(mix)


在此模式下,mysql会根据每条执行的语句,区分对待应用存储的模式.

当表结构发生变化时,将使用语句模式存储

当表数据发生update/delete操作时,使用行模式存储

数据库删库后,如何恢复数据

当数据库被删除后,我们可以通过每周/每天备份的数据库文件中,恢复之前的数据.

同时通过binlog,筛选出备份后未恢复的数据,通过mysqlbinlog命令导出sql,执行回去,即可恢复大部分的数据了.

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
目录
相关文章
|
16天前
|
存储 SQL 关系型数据库
MySQL中binlog、redolog与undolog的不同之处解析
每个都扮演回答回溯与错误修正机构角色: BinLog像历史记载员详细记载每件大大小小事件; RedoLog则像紧急救援队伍遇见突發情況追踪最后活动轨迹尽力补救; UndoLog就类似时间机器可倒带历史让一切归位原始样貌同时兼具平行宇宙观察能让多人同时看见各自期望看见历程而互不干扰.
95 9
|
2月前
|
存储 SQL 关系型数据库
MySQL的Redo Log与Binlog机制对照分析
通过合理的配置和细致的管理,这两种日志机制相互配合,能够有效地提升MySQL数据库的可靠性和稳定性。
87 10
|
4月前
|
SQL 监控 关系型数据库
MySQL日志分析:binlog、redolog、undolog三大日志的深度探讨。
数据库管理其实和写小说一样,需要规划,需要修订,也需要有能力回滚。理解这些日志的作用与优化,就像把握写作工具的使用与运用,为我们的数据库保驾护航。
183 23
|
5月前
|
Oracle 关系型数据库 MySQL
Oracle linux 8 二进制安装 MySQL 8.4企业版
Oracle linux 8 二进制安装 MySQL 8.4企业版
152 1
|
5月前
|
SQL 运维 关系型数据库
MySQL Binlog 日志查看方法及查看内容解析
本文介绍了 MySQL 的 Binlog(二进制日志)功能及其使用方法。Binlog 记录了数据库的所有数据变更操作,如 INSERT、UPDATE 和 DELETE,对数据恢复、主从复制和审计至关重要。文章详细说明了如何开启 Binlog 功能、查看当前日志文件及内容,并解析了常见的事件类型,包括 Format_desc、Query、Table_map、Write_rows、Update_rows 和 Delete_rows 等,帮助用户掌握数据库变化历史,提升维护和排障能力。
|
6月前
|
SQL 存储 关系型数据库
简单聊聊MySQL的三大日志(Redo Log、Binlog和Undo Log)各有什么区别
在MySQL数据库管理中,理解Redo Log(重做日志)、Binlog(二进制日志)和Undo Log(回滚日志)至关重要。Redo Log确保数据持久性和崩溃恢复;Binlog用于主从复制和数据恢复,记录逻辑操作;Undo Log支持事务的原子性和隔离性,实现回滚与MVCC。三者协同工作,保障事务ACID特性。文章还详细解析了日志写入流程及可能的异常情况,帮助深入理解数据库日志机制。
560 0
|
3月前
|
人工智能 运维 关系型数据库
数据库运维:mysql 数据库迁移方法-mysqldump
本文介绍了MySQL数据库迁移的方法与技巧,重点探讨了数据量大小对迁移方式的影响。对于10GB以下的小型数据库,推荐使用mysqldump进行逻辑导出和source导入;10GB以上可考虑mydumper与myloader工具;100GB以上则建议物理迁移。文中还提供了统计数据库及表空间大小的SQL语句,并讲解了如何使用mysqldump导出存储过程、函数和数据结构。通过结合实际应用场景选择合适的工具与方法,可实现高效的数据迁移。
576 1
|
4月前
|
负载均衡 算法 关系型数据库
大数据大厂之MySQL数据库课程设计:揭秘MySQL集群架构负载均衡核心算法:从理论到Java代码实战,让你的数据库性能飙升!
本文聚焦 MySQL 集群架构中的负载均衡算法,阐述其重要性。详细介绍轮询、加权轮询、最少连接、加权最少连接、随机、源地址哈希等常用算法,分析各自优缺点及适用场景。并提供 Java 语言代码实现示例,助力直观理解。文章结构清晰,语言通俗易懂,对理解和应用负载均衡算法具有实用价值和参考价值。
大数据大厂之MySQL数据库课程设计:揭秘MySQL集群架构负载均衡核心算法:从理论到Java代码实战,让你的数据库性能飙升!
|
3月前
|
SQL 关系型数据库 MySQL
Go语言数据库编程:使用 `database/sql` 与 MySQL/PostgreSQL
Go语言通过`database/sql`标准库提供统一数据库操作接口,支持MySQL、PostgreSQL等多种数据库。本文介绍了驱动安装、连接数据库、基本增删改查操作、预处理语句、事务处理及错误管理等内容,涵盖实际开发中常用的技巧与注意事项,适合快速掌握Go语言数据库编程基础。
207 62
|
2月前
|
SQL 存储 关系型数据库
MySQL功能模块探秘:数据库世界的奇妙之旅
]带你轻松愉快地探索MySQL 8.4.5的核心功能模块,从SQL引擎到存储引擎,从复制机制到插件系统,让你在欢声笑语中掌握数据库的精髓!

推荐镜像

更多