当前位置:网站首页>MySQL log articles, binlog log of MySQL log, detailed explanation of binlog log
MySQL log articles, binlog log of MySQL log, detailed explanation of binlog log
2022-08-04 05:31:00 【little things】
一、描述
binlog 二进制日志文件,这个文件记录了MySQL所有的DML操作.通过binlog日志我们可以做数据恢复,增量备份,主主复制和主从复制等等.
二、常用操作
2-1、docker里面无法使用 vim、常用命令问题解决
https://blog.csdn.net/Tomwildboar/article/details/120710690
https://blog.csdn.net/KwaiSZ/article/details/106937983
2-2、开启 binlog
查看是否开启binlog日志 show variables like 'log_%';
在 my.cnf
里面加上配置如下配置,重启mysql.
一般来说 my.cnf 在:/etc/mysql/my.cnf
或 /etc/my.cnf
# binlog存储的位置
log-bin=/var/lib/mysql/mysql-bin
# 日志过期时间
expire_logs_days=30
# 不加这个启动会报错
server-id=123454
如果你启动的时候因为配置文件修改错了,导致无法启动,可以参考这个解决: Mac下docker里面的MySQL无法启动,Mac进入docker(修改配置文件导致无法启动)
查看binlog其它的配置文件 show cc like 'binlog%';
2-3、binlog查看乱码的问题
上面框起来的就是binlog日志
(你可以先对表进行一些增删改操作),但是我们使用 vim打开发现全是乱码
其中标记的部分并非是乱码,而是经由 base64 编码之后的结果,可以在通过 mysqlbinlog 查看 binlog 日志时添加参数进行解码
mysqlbinlog -vv --base64-output=decode-rows mysql-bin.000007
2-4、binlog 编码格式
我们可以使用 show variables like 'binlog_format';
来查看默认的编码格式
注:不同版本的MySQL,binlog默认的编码格式可能不同
binlog有三种编码格式分别是 row
statement
mixed
2-4-1、statement 基于SQL语句的复制(statement-based replication, SBR)
每一条会修改数据的sql语句都会记录到binlog中.优点是并不需要记录每一条sql语句和每一行的数据变化,减少了binlog日志量,节约IO,提高性能.
在配置文件里面加入配置 binlog_format=statement
,然后重启服务.
执行下面的语句
CREATE TABLE `my_test`.`xdx_test` (
`name` varchar(255) NOT NULL,
`age` int(0) NOT NULL,
`birthday` datetime NOT NULL
)
insert into xdx_test (name,age,birthday) values ('xdx',18, now());
然后我们在打开最新的binlog日志,可以在里面找到上面的语句.
但就如同上面的 insert 语句,我使用了 now(),这个函数,如果用这个binlog语句去进行备份、同步那么时间字段就对不上了.
2-4-2、row 基于行的复制(row-based replication, RBR)
不记录每条sql语句的上下文信息,仅需记录哪条数据被修改了,修改成什么样了.而且不会出现某些特定情况下的存储过程、或function、或trigger的调用和触发或 now() 无法被正确复制的问题.缺点是会产生大量的日志,尤其是alter table的时候会让日志暴涨.
修改配置文件为 binlog_format=row
,然后重启服务器即可开启.
2-4-3、mixed 混合模式复制(mixed-based replication, MBR)
以上两种模式的混合使用,一般的复制使用STATEMENT模式保存binlog,对于STATEMENT模式无法复制的操作使用ROW模式保存binlog,MySQL会根据执行的SQL语句选择日志保存方式.
修改配置文件为 binlog_format=mixed
,然后重启服务器即可开启.
2-5、通过binlog恢复数据
2-5-1、准备数据
在操作之前,我们先执行 flush logs;
开启一个新的 binlog日志,方便后面处理.
建表
CREATE TABLE `xdx_test` (
`id` int(1) unsigned NOT NULL AUTO_INCREMENT COMMENT '自增id',
`name` varchar(255) NOT NULL COMMENT '名称',
`age` int(11) NOT NULL COMMENT '年龄',
`birthday` datetime NOT NULL COMMENT '生日' ,
PRIMARY KEY (`id`) USING BTREE
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
添加数据
insert into xdx_test (name, age, birthday) values ('111',111,now());
insert into xdx_test (name, age, birthday) values ('222',222,now());
查看数据
这里我们删掉 id=1
的数据 delete from xdx_test where id = 1;
,用来模拟异常情况数据丢失,然后我们再来恢复它.
2-5-2、恢复数据
2-5-2-1、开启新的日志
执行命令 flush logs
开启新的日志记录,这样我们就不会收到后面操作的干扰.
2-5-2-2、找到我们要操作的日志
这里我要操作的日志是 mysql-bin.000013
执行命令查看日志结构 show binlog events in 'mysql-bin.000013';
2-5-2-3、使用 pos 恢复数据
从上面的图,我们可以看到pos的开始和结束的位置,我们可恢复此阶段的数据
# 进入到 binlog 目录下
cd /var/lib/mysql
# 数据恢复命令
mysqlbinlog --start-position=开始的pos --stop-position=结束的pos --database=要操作的数据库 binlog的名称 | mysql -u登陆名 -p登陆密码 -v 要操作的数据库
# 最终执行命令(我的)
mysqlbinlog --start-position=669 --stop-position=980 --database=my_test mysql-bin.000013 | mysql -uroot -p123456 -v my_test
再次进入数据库,查询,发现数据有了
2-5-2-4、使用时间恢复数据
使用命令查看binlog日志 mysqlbinlog -vv --base64-output=decode-rows mysql-bin.000013
数据比较多,这里我只截图需要的部分
mysqlbinlog --start-datetime='2021-10-14 12:47:12' --stop-datetime='2021-10-14 12:52:40' --database=my_test mysql-bin.000013 | mysql -uroot -p123456 -v my_test
2-N、其他
2-N-1、binlog 文件大小
可以使用命令来查看binlog 单个文件大小,默认是1G,如果超过了1G就会新增一个文件 show variables like 'max_binlog_size';
注: 当你重启MySQL的时候,就会新增一个新的 binlog 文件
2-N-2、过期删除
前面也说了,我们可以使用 expire_logs_days=30
来配置日志保存时间,我们最好不要自己去删除binlog日志,这样会导致过期删除出错,如果非要删除,要记得更新一下 xxxxx.mysql-bin.index
2-N-3、其它命令
- 查看全部的日志
show master logs;
- 查看日志的最后一次操作
show master status;
- 刷新binlog日志,也就是新开启一个日志文件
flush logs
(这个在恢复数据的时候很有用)
2-N-4、 sync_binlog
sync_binlog=0,当事务提交之后,MySQL不做fsync之类的磁盘同步指令刷新binlog_cache中的信息到磁盘,而让Filesystem自行决定什么时候来做同步,或者cache满了之后才同步到磁盘.
sync_binlog=1,强一致,每次事物提交都进行磁盘同步.
sync_binlog=n,当每进行n次事务提交之后,MySQL将进行一次fsync之类的磁盘同步指令来将binlog_cache中的数据强制写入磁盘
参考文章
https://www.cnblogs.com/xingyunfashi/p/8431780.html
https://www.cnblogs.com/YCcc/p/10825870.html
先自我介绍一下,小编13年上师交大毕业,曾经在小公司待过,去过华为OPPO等大厂,18年进入阿里,直到现在.深知大多数初中级java工程师,想要升技能,往往是需要自己摸索成长或是报班学习,但对于培训机构动则近万元的学费,着实压力不小.自己不成体系的自学效率很低又漫长,而且容易碰到天花板技术停止不前.因此我收集了一份《java开发全套学习资料》送给大家,初衷也很简单,就是希望帮助到想自学又不知道该从何学起的朋友,同时减轻大家的负担.添加下方名片,即可获取全套学习资料哦
边栏推荐
猜你喜欢
7.18 Day23----标记语言
npm报错Beginning October 4, 2021, all connections to the npm registry - including for package installa
Typora 使用保姆级教程 | 看这一篇就够了 | 历史版本已被禁用
SLSA 框架与软件供应链安全防护
部署LVS-DR群集【实验】
触觉智能分享-SSD20X实现升级显示进度条
代码重构:面向单元测试
leetcode 12. Integer to Roman numeral
leetcode 12. 整数转罗马数字
sql server如何得到本条记录与上一条记录的差异,即变动值
随机推荐
C Expert Programming Chapter 4 The Shocking Fact: Arrays and Pointers Are Not the Same 4.5 Other Differences Between Arrays and Pointers
力扣:509. 斐波那契数
【一步到位】Jenkins的安装、部署、启动(完整教程)
使用Patroni回调脚本绑定VIP的坑
C专家编程 第5章 对链接的思考 5.2 动态链接的优点
处理List<Map<String, String>>类型
使用Loadrunner进行性能测试
[SemiDrive source code analysis] [MailBox inter-core communication] 47 - Analysis of RPMSG_IPCC_RPC mode limit size of single transmission and limit bandwidth test
C专家编程 第4章 令人震惊的事实:数组和指针并不相同 4.4 使声明与定义相匹配
MySQL数据库面试题总结(2022最新版)
有趣的 Kotlin 0x0E:DeepRecursiveFunction
As soon as flink cdc is started, the CPU of the source Oracle server soars to more than 80%. What is the reason?
sql server如何得到本条记录与上一条记录的差异,即变动值
2023年PMP考试会用新版教材吗?回复来了!
8. Custom mapping resultMap
DP4398:国产兼容替代CS4398立体声24位/192kHz音频解码芯片
深度学习21天——卷积神经网络(CNN):实现mnist手写数字识别(第1天)
static在不同位置定义变量居然还有不同的含义?
Delphi-C端有趣的菜单操作界面设计
8大软件供应链攻击事件概述