• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    如何区分MySQL的innodb_flush_log_at_trx_commit和sync_binlog

    innodb_flush_log_at_trx_commit和sync_binlog  两个参数是控制MySQL磁盘写入策略以及数据安全性的关键参数。

    show variables like "innodb_flush_log_at_trx_commit";

    innodb_flush_log_at_trx_commit:

    0: 由mysql的main_thread每秒将存储引擎log buffer中的redo日志写入到log file,并调用文件系统的sync操作,将日志刷新到磁盘。

    1:每次事务提交时,将存储引擎log buffer中的redo日志写入到log file,并调用文件系统的sync操作,将日志刷新到磁盘。

    2:每次事务提交时,将存储引擎log buffer中的redo日志写入到log file,并由存储引擎的main_thread 每秒将日志刷新到磁盘。

    show variables like "sync_binlog";

    sync_binlog:

    0 :存储引擎不进行binlog的刷新到磁盘,而由操作系统的文件系统控制缓存刷新。

    1:每提交一次事务,存储引擎调用文件系统的sync操作进行一次缓存的刷新,这种方式最安全,但性能较低。

    n:当提交的日志组=n时,存储引擎调用文件系统的sync操作进行一次缓存的刷新。

    sync_binlog=0或sync_binlog大于1,事务被提交,而尚未同步到磁盘。因此,在电源故障或操作系统崩溃时有可能服务器已承诺尚未同步一些事务到二进制日志。因此它是不可能执行例行程序恢复这些事务,他们将会丢失二进制日志。

    innodb_flush_log_at_trx_commit和sync_binlog 都为 1 时是最安全的,在mysqld 服务崩溃或者服务器主机crash的情况下,binary log 只有可能丢失最多一个语句或者一个事务。但是鱼与熊掌不可兼得,双1,1 会导致频繁的io操作,因此该模式也是最慢的一种方式。

    实际使用时,要考虑业务方对性能和安全性的需求,综合考量设置,两个参数。上图中是我们线上机器的参数。

    以上就是如何区分MySQL的innodb_flush_log_at_trx_commit和sync_binlog的详细内容,更多关于MySQL的innodb_flush_log_at_trx_commit和sync_binlog的资料请关注脚本之家其它相关文章!

    您可能感兴趣的文章:
    • MySQL InnoDB架构的相关总结
    • MySQL InnoDB ReplicaSet(副本集)简单介绍
    • 详解MySQL InnoDB存储引擎的内存管理
    • MySQL Innodb关键特性之插入缓冲(insert buffer)
    • MySQL InnoDB 锁的相关总结
    • Mysql InnoDB的锁定机制实例详解
    • Mysql技术内幕之InnoDB锁的深入讲解
    • 修改MySQL数据库引擎为InnoDB的操作
    • 简述MySQL InnoDB存储引擎
    • MySQL InnoDB表空间加密示例详解
    • MySQL InnoDB 事务锁源码分析
    上一篇:MySQL 日志相关知识总结
    下一篇:Mysql主键UUID和自增主键的区别及优劣分析
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    如何区分MySQL的innodb_flush_log_at_trx_commit和sync_binlog 如何,区分,MySQL,的,innodb,