innodb_flush_log_at_trx_commit和sync_binlog 参数说明

来源:互联网 发布:cctv网络直播电视大全 编辑:程序博客网 时间:2024/05/17 10:40
  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
原创粉丝点击