iblog binlog mysql_MySQL之binlog与redo log区别

一、REDO LOG

1、什么是redo log?

redo log又称为重做日志文件,用于记录事务操作的变化,记录的是数据修改之后的值,不管事务是否提交都会记录下来。InnoDB存储引擎会使用redo log恢复数据,以此来保证数据的完整性。

注:它是InnoDB专有的日志。

2、redo log的文件

每个InnoDB存储引擎至少有1个重做日志文件组(group),每个组至少有2个重做日志文件。

默认安装情况下,redo log只有一组,两个日志文件,如:ib_logfile0和ib_logfile1。

3、redo log相关参数

innodb_log_file_size:每个redo日志大小,默认为48MB;

innodb_log_files_in_group:每个日志文件组中redo日志文件数量,默认为2;

innodb_log_group_home_dir:日志文件组所在路径,默认值./,指mysql的数据目录datadir;

innodb_mirrored_log_groups:日志镜像文件组的数量,默认为1,此功能属于未实现的功能,在5.6版本中废弃,在5.7版本中已删除。

注:日志设置太大,需恢复时间则长;如果设置太小,则频繁刷新,降低性能。目前恢复速度有了很大提升,建议增大日志,适度增大缓存innodb_log_buffer_size。

二、BINLOG

1、什么是binlog?

binlog记录数据库更改的所有操作,但是不包括SELECT和SHOW这类操作,因为这类操作对数据本身并没有修改。然后,如果操作本身并没有导致数据库发生变化,那么该操作也会写入二进制日志。(比如一个update语句没有产生变化,也会被记录)

注:如果想记录SELECT和SHOW操作,修改参数–general_log[={0|1}(1为启用)

2、binlog相关参数

log-bin[=name]:可以启动二进制日志。如果不指定,则默认binlog日志文件名为主机名,后缀名为binlog的序列号,默认路劲为数据目录(datadir).你也可以指定绝对路径。

max_binlog_size:指定单个binlog文件最大值。默认值为1g,最大值1g,如果超过该值,则产生新的binlog文件,后缀名+1,并记录到.index文件。

binlog_cache_size:使用事务表存储引擎(如innodb存储引擎)时,所有未提交的binlog日志会被记录到一个缓存中去,等事务提交时再将缓存中的binlog写入到binlog文件中。缓存的大小由binlog_cache_size决定,默认大小为32K。

注:此参数是基于session的,避免太大。但也要避免太小,影响IO。

max_binlog_cache_size:如果事务需要的内存超过很多字节,则服务器会生成多于“max_binlog_cache_size”字节的存储错误所需的并发事务。 最小值为4096字节,最大可能值为16EB(exabytes)。 建议的最大值为4GB; 这是因为MySQL目前无法使用大于4GB的二进制日志位置。

expire_logs_days:表示binlog文件自动删除N天前的文件。默认值为0,表示不自动删除,最大值99.要手动删除binlog文件,可以使用purge binary logs语句。

binlog_rows_query_log_events:默认为不启用,启用binlog_rows_query_log_events时,可以在binary log中记录原始的SQL语句。

sync_binlog:sync_binlog=[N]表示没写缓冲N次就同步到磁盘,如果将N设为1,即sync_binlog表示采用同步写磁盘的方式来写二进制日志,在MySQL5.7.7后,默认为1。会对数据库的IO系统带来一定影响,但可以得到最大的高可用性。

binlog_checksum:该参数目的就是写入binlog进行校验,有两个值[crc32|none],默认为crc32

binlog-do-db:表示需要写入日志的数据库,默认为空,表示同步所有库

binlog-ignore-db:表示忽略写入日志的数据库,默认为空,表示同步所有库

log-slave-update:表示从master端取得并执行的binlog,写入自己的binlog文件中,一般应用在master=>slave=>slave架构

binlog_format:记录binlog的格式。[statement,row,mixed],在MySQL5.7.7之后,默认为row。

三、binlog与redo log区别

1、redo log是在InnoDB存储引擎层产生。

binlog是MySQL数据库的server层产生的,对所有引擎都会产生二进制日志。

2、两种日志记录的内容形式不同。binlog是逻辑日志,支持三种行式,statement、row、mixed。redo log是物理日志,保存的是变化的数据。

3、两种日志与记录写入磁盘的时间点不同。二进制日志只在事务提交完成后进行一次写入。

innodb的重做日志在事务进行中不断地被写入,而且日志不是随事务提交的顺序进行写入的。

4、binlog不是循环使用,在写满或者重启之后,会生成新的binlog文件。

redo log是循环使用。

5、binlog可以作为恢复数据使用,主从复制搭建。

redo log作为异常宕机或者介质故障后的数据恢复使用。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值