innodb_flush_log_at_trx_commit和sync_binlog 参数说明

  1. innodb_flush_log_at_trx_commit  写的是redo log  
  2.   
  3.   
  4. sync_binlog 写的binlog  
  5.   
  6.   
  7. 如果 innodb_flush_log_at_trx_commit的值是0,log buffer 被写出到log 文件 是一秒一次  
  8.   
  9.   
  10. flush 到disk的操作被执行在log 文件上,但是在事务提交的时候什么都不做。  
  11.   
  12.   
  13. 当值是1 的时候(默认的), log buffer 被写入到log file 是每个事务提交的时候,写出到磁盘操作被执行。  
  14.   
  15.   
  16.   
  17. 当值是2的时候,log buffer 是写出到文件在每次提交的时候,但是flush 到磁盘操作是不执行的。  
  18.   
  19.   
  20. 然而, flush日志发生是一秒一次 当值为2的时候。  
  21.   
  22.   
  23. 注意 一秒一次flush 不是100%强制发生的,由于进程调度原因。  
  24.   
  25. 默认值1是为了保证完整的ACID, 你可以得到更好的性能通过设置值不为1,  
  26.   
  27. 但是在系统崩溃的时候,你将会丢失1秒的数据。  
  28.   
  29. 设为0的话,mysqld进程崩溃的时候,就会丢失最后1秒的事务。  
  30.   
  31.   
  32. 设为2的话,只有当操作系统 crash 或者断电会 丢失最后1秒的事务。  
  33.   
  34. 然而, InnoDB做 crash 恢复是不受影响的 因此crash recovery 做恢复的时候 会忽略这个值)  
  35.   
  36. 为最大可能的耐久性和一致性的复制设置 使用了InnoDB 的事务环境  
  37.   
  38. use innodb_flush_log_at_trx_commit = 1 and sync_binlog = 1  
  39.   
  40.   
  41. 小心:  
  42.   
  43. 很多的操作系统和一些磁盘硬件欺骗flush-to-disk操作。  
  44.   
  45. 它们可能告诉mysqld flush已经发生, 尽管它还没有。  
  46.   
  47. 然后交易的耐久性是不强制的 尽管设置为1, 最坏的情况能corrupt the InnoDB database。  
  48.   
  49.   
  50. 使用电池备份磁盘高速缓存的SCSI 盘控制器或者 在磁盘本身加快文件刷新  
  51.   
  52.   
  53.   
  54.   
  55. 如果sync_binlog值大于0, MYSQL server 同步它的binary log 到磁盘(使用fdatasync())  
  56.   
  57. 在每次sync_binlog 写到binary log.如果自动提交启用,会把每个语句写到binary log里  
  58.   
  59.   
  60. 默认值是0,不是同步写到磁盘的 在这种情况下, server 依赖操作系统来flush binary log的内存  
  61.   
  62.   
  63. 值设为1 是安全的选择,由于crash 你最多丢失一个语句或者事务。然而,那也是最慢的选择 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
解决MySQL主从延时的方法之一是通过临时修改sync_binlog参数innodb_flush_log_at_trx_commit参数来实现。具体介绍如下: 1. sync_binlog参数: - 该参数用于控制二进制日志的同步方式。默认情况下,sync_binlog参数的值为1,表示每次事务提交时都会将二进制日志同步到磁盘上。 - 临时将sync_binlog参数设置为5000,意味着每隔5000个事务提交才会将二进制日志同步到磁盘上,从而减少了磁盘IO的频率,提高了性能。 - 但是,这样做也增加了数据丢失的风险,因为如果在两次同步之间发生故障,可能会丢失最近的5000个事务的数据。 2. innodb_flush_log_at_trx_commit参数: - 该参数用于控制InnoDB存储引擎的日志刷新策略。默认情况下,innodb_flush_log_at_trx_commit参数的值为1,表示每次事务提交时都会将日志刷新到磁盘上。 - 临时将innodb_flush_log_at_trx_commit参数设置为0,意味着每次事务提交时不会立即将日志刷新到磁盘上,而是由InnoDB引擎自行决定刷新的时机。 - 这样做可以提高性能,减少磁盘IO的频率,但也增加了数据丢失的风险,因为在发生故障时可能会丢失最近提交的事务的数据。 利弊如下: - 利:通过临时修改sync_binlog参数innodb_flush_log_at_trx_commit参数,可以减少磁盘IO的频率,提高数据库的性能。 - 弊:临时修改这两个参数会增加数据丢失的风险,因为在发生故障时可能会丢失最近提交的事务的数据。此外,如果忘记还原这些参数的值,可能会导致数据不一致或数据丢失的问题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值