如何区分MySQL的innodb_flush_log_at_trx_commit和sync_binlog

作者:bloomingTony 时间:2024-01-19 19:38:30 

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

show variables like "innodb_flush_log_at_trx_commit";

如何区分MySQL的innodb_flush_log_at_trx_commit和sync_binlog

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";

如何区分MySQL的innodb_flush_log_at_trx_commit和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操作,因此该模式也是最慢的一种方式。

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

来源:https://mp.weixin.qq.com/s?__biz=MzU4NjQwNTE5Ng==&mid=2247483681&idx=1&sn=03adfb89521568013f6a1efd9ca1af6a&scene=21#wechat_redirect

标签:MySQL,innodb,flush,log,at,trx,commit,sync,binlog
0
投稿

猜你喜欢

  • python 日期排序的实例代码

    2023-12-02 16:09:35
  • Python模块的制作方法实例分析

    2021-09-06 05:57:26
  • python uuid生成唯一id或str的最简单案例

    2021-06-07 00:40:45
  • JavaScript也谈内存优化

    2024-02-25 16:33:17
  • python标准库之time模块的语法与简单使用

    2023-06-11 17:42:23
  • asp在sql server2000中新建帐号和给帐号权限代码

    2008-01-29 13:46:00
  • 卓越网的配送服务让我很不满意

    2009-03-19 13:49:00
  • 改善IE6中a与a:hover的背景支持

    2009-11-27 18:50:00
  • Oracle中pivot函数图文实例详解

    2023-07-12 22:13:49
  • MySQL安全性指南 (1)(转)

    2010-07-27 12:49:00
  • 基于PHP实现一个简单的在线聊天功能

    2024-05-03 15:52:38
  • numpy 矩阵形状调整:拉伸、变成一位数组的实例

    2021-12-15 06:40:02
  • 监控 url fragment变化的js代码

    2023-08-25 10:20:58
  • python语言中pandas字符串分割str.split()函数

    2022-01-30 16:55:56
  • pytorch实现ResNet结构的实例代码

    2022-12-31 01:50:48
  • Django中ajax发送post请求 报403错误CSRF验证失败解决方案

    2021-06-11 19:47:32
  • 如何用Navicat操作MySQL

    2024-01-15 20:56:37
  • Go语言fsnotify接口实现监测文件修改

    2024-05-13 10:45:07
  • Python内置加密模块用法解析

    2021-09-17 02:26:19
  • 有感用户体验规划与系统实现

    2009-11-27 18:33:00
  • asp之家 网络编程 m.aspxhome.com