admin管理员组文章数量:1577821
目录
一、介绍
二、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恢复数据 内容由热心网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:https://www.elefans.com/dianzi/1726035263a1052853.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论