Redo Log(重做日志)的刷盘策略

1. 概述

在这里插入图片描述

Redo Log(重做日志)是 InnoDB 存储引擎中的一种关键组件,用于保障数据库事务的持久性和崩溃恢复。InnoDB 将事务所做的更改先记录到重做日志,之后再将其应用到磁盘上的数据页。

刷盘策略(Flush Policy)指的是将内存中的重做日志内容刷写(写入)到磁盘的方式和时间点,以确保数据的持久性和一致性。InnoDB 使用多种策略来处理重做日志的刷盘操作:

  1. WAL(Write-Ahead Logging):InnoDB 是一种WAL存储引擎,它要求在事务提交前将重做日志刷新到磁盘。这意味着在事务提交时,相关的重做日志需要被持久化,确保即使在数据库崩溃的情况下,可以通过重做日志进行崩溃恢复。

  2. Checkpoint:InnoDB 定期执行检查点操作,将内存中的脏页(已被修改但尚未写入磁盘的页)写入磁盘。在执行检查点时,也会确保相关的重做日志已经被持久化。检查点的频率可以通过配置参数来调整。

  3. Write-Ahead Log (WAL) Commit:在 InnoDB 中,事务的提交不仅仅意味着数据页的修改,同时也包括了重做日志的写入。事务提交时,相关的重做日志需要立即被刷新到磁盘。

  4. Double Write Buffer:InnoDB 使用了双写缓冲机制,它可以在写入磁盘之前将磁盘写操作先写入一个缓冲区,以避免数据写入过程中出现的意外崩溃或错误。这有助于确保数据的完整性。

这些策略的综合使用确保了数据库在事务提交后、定期执行检查点、或者在系统崩溃时,都能保持数据的一致性和持久性。通过这些刷盘策略,InnoDB 能够保证在数据库恢复过程中不会丢失提交的事务数据。
在这里插入图片描述

2. 如何手动设置刷盘策略

在 MySQL 中,可以通过设置不同的参数和配置来手动调整 InnoDB 存储引擎的刷盘策略。这些配置可以通过修改 MySQL 的配置文件(通常是 my.cnf 或 my.ini)来实现。以下是一些常用参数和配置:

  1. innodb_flush_log_at_trx_commit:这个参数控制事务提交时日志的刷盘策略,它有三个可选的值:

    • innodb_flush_log_at_trx_commit = 1:每次事务提交时都会将日志刷新到磁盘,确保了最高的持久性(默认值)。
    • innodb_flush_log_at_trx_commit = 2:日志写入到操作系统的缓存(log buffer)并每秒刷写到磁盘(可能会存在少量数据丢失的风险,但提高性能)。
    • innodb_flush_log_at_trx_commit = 0:日志写入到操作系统的缓存(log buffer),并每次检查点时刷写到磁盘(可能存在更多的数据丢失风险)。
  2. innodb_flush_method:用于设置 InnoDB 存储引擎刷写日志和数据文件的方法,其选项包括:

    • innodb_flush_method = fsync:使用标准的 fsync() 系统调用来刷新数据。
    • innodb_flush_method = O_DIRECT:直接写入磁盘而不使用操作系统缓存。
    • 其他值取决于 MySQL 版本和操作系统的支持。
  3. innodb_doublewrite:控制 InnoDB 双写缓冲的开启或关闭,用于数据完整性保护。

    • innodb_doublewrite = 1:开启双写缓冲(默认)。
    • innodb_doublewrite = 0:关闭双写缓冲。
      请注意,更改这些参数可能会对数据库的性能和数据持久性产生影响。在调整这些设置之前,请确保对数据库性能和安全性影响的潜在风险有足够的了解,并进行充分的测试。

要应用这些设置,你可以编辑 MySQL 的配置文件,将所需的参数值设置为适合你需求的值,然后重启 MySQL 服务以使更改生效。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/179509.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

如何记录每天的工作日程?电脑手机通用的日程管理软件

在工作时间有限,但工作任务愈加繁多的现在职场中,要求每一个职场人士做好高效日程管理。通过高效管理日程,我们可以更好地组织和安排任务,合理分配时间和优先级,这有助于我们更专注地进行工作,减少时间的浪…

MCU HardFault_Handler调试方法

一.获取内核寄存器的值 1.在MDK的DEBUG模式下,当程序出现跑飞后,确定卡死在HardFault_Handler中断处 2. 通过Register窗口读取LR寄存器的值来确定当前系统使用堆栈是MSP还是PSP LR寄存器值堆栈寄存器0xFFFFFFF9MSP寄存器0xFFFFFFFDPSP寄存器 如下图所…

【JavaEE】cookie和session

cookie和session cookie什么是 cookieServlet 中使用 cookie相应的API Servlet 中使用 session 相应的 API代码示例: 实现用户登陆Cookie 和 Session 的区别总结 cookie 什么是 cookie cookie的数据从哪里来? 服务器返回给浏览器的 cookie的数据长什么样? cookie 中是键值对…

HR模块开发(1):简单的开发流程和注意事项

HR模块开发 一、模块概述 人力资源管理解决方案关注3个领域:每位雇员都发展和维护着‘公司内’和‘公司外’的种种‘关系’。运用科技,强化这些关系,可以提高忠诚度和生产力,公司整体得到商业价值。 员工关系管理员工职业生命周期管理员工事务处理管理HR模块的基本知识和构…

[Unity][VR]透视开发系列4-解决只看得到Passthrough但看不到Unity对象的问题

【视频资源】 视频讲解地址请关注我的B站。 专栏后期会有一些不公开的高阶实战内容或是更细节的指导内容。 B站地址: https://www.bilibili.com/video/BV1Zg4y1w7fZ/ 我还有一些免费和收费课程在网易云课堂(大徐VR课堂): https://study.163.com/provider/480000002282025/…

算法通关村第四关-黄金挑战基础计算器问题

大家好我是苏麟 , 今天带来栈的比较难的问题 . 计算器问题 基础计算器 LeetCode 224 描述 : 给你一个字符串表达式 s ,请你实现一个基本计算器来计算并返回它的值。 s 由数字、、-、(、)、和 组成s 表示一个有效的表达式 不能用作一元运算(例如, …

2014年亚太杯APMCM数学建模大赛A题无人机创造安全环境求解全过程文档及程序

2014年亚太杯APMCM数学建模大赛 A题 无人机创造安全环境 原题再现 20 国集团,又称 G20,是一个国际经济合作论坛。2016 年第 11 届 20 国集团峰会将在中国召开,这是继 APEC 后中国将举办的另一个大型峰会。此类大型峰会,举办城市…

【计算机网络】浏览器的通信能力

1. 用户代理 浏览器可以代替用户完成http请求,代替用户解析响应结果,所以我们称之为用户代理 user agent。 浏览器两大核心能力: 自动发送请求的能力自动解析响应的能力 1.1 自动发送请求的能力 用户在地址栏输入了一个url地址&#xff0…

[双指针] (四) LeetCode 18.四数之和

[双指针] (四) LeetCode 18.四数之和 文章目录 [双指针] (四) LeetCode 18.四数之和题目解析解题思路代码实现总结 18. 四数之和 题目解析 (1) 从一个数组中找一个目标值target (2) target nums[a] nums[b] nums[c] nums[d] 解题思路 和上一道题三数之和一样, 我们把四…

Android笔记(十一):Compose中使用ViewModel

通过ViewModel组件用于保存视图中需要的数据。ViewModel主要目的是将与用户界面相关的数据模型和应用程序的逻辑与负责实际显示和管理用户界面以及与操作系统交互的代码分离开来,为UI界面管理数据。常见的管理方式主要有:LiveData和StateFlow两种形式来实…

Redis常见风险分析

击穿 概念:在Redis获取某一key时, 由于key不存在, 而必须向DB发起一次请求的行为, 称为“Redis击穿”。 引发击穿的原因: 第一次访问恶意访问不存在的keyKey过期 合理的规避方案: 服务器启动时, 提前写入规范key的命名, 通过中间件拦截对…

BUUCTF FLAG 1

BUUCTF:https://buuoj.cn/challenges 题目描述: 注意:请将 hctf 替换为 flag 提交,格式 flag{} 密文: 下载附件,得到一张.png图片。 解题思路: 1、因为附件是一张图片,先放到StegSolve中&…

CentOS 7使用RPM包安装MySQL5.7

目标 本文目标是简单介绍如何在CentOS 7上使用RPM包安装MySQL 5.7,然后描述如何调整存储路径datadir。 环境准备 操作系统 —— CentOS 7MySQL版本 —— MySQL 5.7.44 获取MySQL-rpm包 官网下载地址:https://dev.mysql.com/downloads/mysql/5.7.htm…

mysql之事务

1、事务的定义 事务是一种机制,一个操作序列,包含了一组数据库的操作命令,所有命令都是一个整体,作为一个整体向系统提交或者撤销的操作,要么都执行,要么都不执行,是一个不可分割的单位 2、事…

Modelsim 使用教程(3)——Projects

目录 一、概述 二、设计文件及tb 2.1 设计文件 counter.v 2.2 仿真文件 tcounter.v 三、操作流程 3.1 Create a New Project(创建一个新的工程) 3.2 Add Objects to the Project(把代码加入项目) 3.3 Compile the …

【44.全排列Ⅱ】

目录 一、题目描述二、算法原理三、代码实现 一、题目描述 二、算法原理 三、代码实现 class Solution { public:vector<vector<int>> ret;vector<int> path;vector<bool> check;vector<vector<int>> permuteUnique(vector<int>&am…

winscp文件增量同步到linux服务器

一&#xff0c;点击同步 场景&#xff1a;在做服务器迁移的时候&#xff0c;文件好几十个G一天也迁移不完&#xff0c;每天还有增量的文件&#xff0c;先全量同步一次&#xff0c;然后再用增量同步&#xff0c;然后你用winscp的同步工具&#xff0c;进增量同步。 将本地文件同…

k8s 资源预留

KUBERNETES资源管理之–资源预留 Kubernetes 的节点可以按照 Capacity 调度。node节点本身除了运行不少驱动 OS 和 Kubernetes 的系统守护进程&#xff0c;默认情况下 pod 能够使用节点全部可用容量&#xff0c; 除非为这些系统守护进程留出资源&#xff0c;否则它们将与 pod 争…

BUUCTF 另外一个世界 1

BUUCTF:https://buuoj.cn/challenges 题目描述&#xff1a; 下载附件&#xff0c;解压得到一个.jpg图片。 密文&#xff1a; 解题思路&#xff1a; 1、这道题我尝试了很多方法&#xff0c;知道看了别人的wp才知道flag在我忽略的地方。将图片在010 Editor中打开&#xff0c;从…

服务号升级订阅号的流程

服务号和订阅号有什么区别&#xff1f;服务号转为订阅号有哪些作用&#xff1f;首先我们要知道服务号和订阅号有什么区别。服务号侧重于对用户进行服务&#xff0c;每月可推送4次&#xff0c;每次最多8篇文章&#xff0c;发送的消息直接显示在好友列表中。订阅号更侧重于信息传…