--------------------------------------------------2015-02-10--------------------------------------------------

(为了节约写作时间,本文部分简称'重做日志'为'日志')

默认情况下, innodb存储引擎的数据目录下有两个文件,ib_logfile0和ib_logfile1. 这就是innodb存储引擎的日志文件了.也叫重做日志文件. 它们记录了innodb存储引擎的事务日志.

该日志文件用于保证innodb的数据完整性.

一.重做日志文件结构:

每一个innodb存储引擎至少有一组日志文件, 每组日志文件至少由2个文件组成.就像上面的所说的,ib_logfile0和ib_logfile1. innodb以循环写入的方式写入日志,例如先写ib_logfile0,当ib_logfile0被写满时,将接下来的内容写入ib_logfile1,当ib_logfile1被写满时又回到ib_0. 所以这两个(或n+1个)日志文件理论上说大小应该是保持一致的.  另外可同过参数innodb_mirrored_log_group参数(设置日志镜像)和innodb_log_group_home参数(设置日志文件组所在路径, './'为数据库数据目录下), 若将日志存放与不同的磁盘上,可提高innodb整体性能.

二. 重做日志与mysql二进制日志的区别:

1. 二进制日志会记录所有与mysql数据库有关的日志记录,包括,innodb,myisam, 等其他存储引擎的日志.     重做日志只记录innodb本身的事务日志.

2. 记录内容. 二进制日志记录的是一个事务的具体操作内容 . 重做日志记录的是关于每个页的更改的物理情况.

3. 写入时间: 二进制日志在每次事务commit时写入 .重做日志在事务进行中(commit之前)同样进行写入操作. 重做日志的操作并不是直接日入文件,而是先写入一个重做日志缓存中,然后按照一定顺序写入文件.(重做日志的写入过程). 重做日志是按512字节也就是一个扇区的大小,因为扇区是写入(磁盘)的最小单位,因为日志的写入必定是成功的.因此在重做日志的写入过程中不需要有两次写入(double write)

三 .重做日志写入条件 :

 1. mysql 主线程(master thread)每秒/每10秒会将重做日志写入到文件,即使在事务中没有进行提交操作(commit).

2. innodb_flush_log_at_trx_commit 参数. 该参数有三个有效值. 分别为:

   0 : 即当事务提交时(sql执行时,非commit操作),不将日志写入日志文件, 而只能由主线程进行每秒/每10秒的刷新. (这个值网上多文章解释为不写入日志文件).

1: 当事务提交时 ,重做日志缓同步到日志文件, 即伴有fsync操作.

2: 标识将重做日志异步刷新到磁盘, 即提交事务时,将日志内容写入到操作系统缓存. 稍后(具体不清楚)将系统缓存写入到日志文件中. 如果在日志记录并未写入到文件中,mysql 意外关闭,但操作系统正常运行. 当下次mysql启动时, 系统缓存中的日志内容仍然可用.如果操作系统挂了, 重做日志就没办法恢复了.     注:一般为了提升innodb的写入性能,可将innodb_flush_log_at_trx_commit设置为2.

--------------------------------------------------2015-02-10--------------------------------------------------

redo log 重做日志的更多相关文章

  1. redo log重做日志缓冲

    ---------------------------------- 2015-02-10---------------------------------- innodb redo log (重做日 ...

  2. 【REDO】删除REDO LOG重做日志组后需要手工删除对应的日志文件(转)

    为保证重新创建的日志组成员可以成功创建,我们在删除日志组后需要手工删除对应的日志文件. 1.查看数据库当前REDO LOG日志相关信息1)查看日志组信息sys@ora10g> select * ...

  3. MySQL日志系统:redo log与binlog

    日志系统主要有redo log(重做日志)和binlog(归档日志).redo log是InnoDB存储引擎层的日志,binlog是MySQL Server层记录的日志, 两者都是记录了某些操作的日志 ...

  4. 深入学习MySQL 02 日志系统:bin log,redo log,undo log

    上一篇文章中,我们了解了一条查询语句的执行过程,按理说这篇应该讲一条更新语句的执行过程,但这个过程比较复杂,涉及到了好几个日志与事物,所以先梳理一下3个重要的日志,bin log(归档日志).redo ...

  5. 数据库中的两个最重要的日志redo log和binlog

    mysql整体来看其实只有两部分,一部分是server层,一部分是引擎层. 1.redo log(重做日志):当有一条记录需要更新的时候,InnoDB 引擎就会先把记录写入redo log里面,并更新 ...

  6. MySQL的两种日志类型,redo log,binlog

    文章内容学习:极客时间-林晓彬老师-MySQL实战45讲 整理而得 我们知道MySQL数据库在发生意外宕机的情况下,可以将数据恢复到历史的某个时间点,能实现这个功能依靠的是日志,MySQL提供两种类型 ...

  7. MySQL日志系统bin log、redo log和undo log

    MySQL日志系统bin log.redo log和undo log   今人不见古时月,今月曾经照古人. 简介:日志是MySQL数据库的重要组成部分,记录着数据库运行期间各种状态信息,主要包括错误日 ...

  8. Oracle重做日志和日志挖掘

    重做日志-Redo log 首先给出参考资料: 1.Oracle官网-Managing the Redo Log 为什么需要redo log 内存中数据修改后,不必立即更新到磁盘---效率 由日志完成 ...

  9. 详细分析MySQL事务日志(redo log和undo log)

    innodb事务日志包括redo log和undo log.redo log是重做日志,提供前滚操作,undo log是回滚日志,提供回滚操作. undo log不是redo log的逆向过程,其实它 ...

随机推荐

  1. mac上安装npm

    检查brew -v是否安装了homebrew这个macOS 缺失的软件包的管理器.如果安装,跳转到第3步,否则跳转到第二步: 安装homebrew.安装跳转到官网指导.等待安装好之后,输入brew - ...

  2. Web服务器—Nginx

    Nginx常用命令: 启动nginx服务 [root@localhost ~]# service nginx start [root@localhost ~]# systemctl start ngi ...

  3. Ubuntu 18.04安装 pyenv、pyenv-virtualenv、virtualenv、Numpy、SciPy、Pillow、Matplotlib

    1.目前Python版本管理工具有很多,pyenv是比较好用的一款,安装如下: 输入: git clone https://github.com/pyenv/pyenv.git ~/.pyenv ec ...

  4. 1. java 基本规则

    一.命名规范 1. 类名规范:首字母大写,后面每个单词首字母大写(大驼峰式),HelloWorld 2. 变量名规范:首字母小写,后面每个单词首字母大写(小驼峰式),helloWorld 3. 方法名 ...

  5. linux下C/C++编译时系统搜索 include 和 链接库 文件路径的指定

     C/C++程序在linux下被编译和连接时,GCC/G++会查找系统默认的include和link的路径,以及自己在编译命令中指定的路径.自己指定的路径就不说了,这里说明一下系统自动搜索的路径.   ...

  6. win10安装配置mongodb

    1. 下载MongoDB并安装官网下载地址:https://blog.csdn.net/qq_41127332/article/details/80755595 ,选择合适的版本进行下载.我选择是3. ...

  7. ubuntu系统中查看python模块的源码

    案例:查看multiprocessing模块源码 1. 进入交互模式,导入模块,以multiprocessing模块为例 2. 查看multiprocessing.__file__属性,找到该模块的源 ...

  8. luoguP3233 [HNOI2014]世界树

    题意 看见数据范围就知道是虚树,于是先建出虚树. 考虑先求出虚树上的点的管理点,显然两边dfs,一遍从下往上,一遍从上往下. 之后考虑不在虚树上的点,对于虚树上的每一条边\((u,v)\),我们考虑上 ...

  9. 工具资源系列之给 windows 虚拟机装个 windows

    前面我们已经介绍了如何在 Windows 宿主机安装 VMware 虚拟机,这节我们将利用安装好的 VMware 软件安装 Windows 系统. 前情回顾 虚拟机是相对于真实的物理机而言的概念,是在 ...

  10. 【2019.8.9 慈溪模拟赛 T1】数论(a)(打表找规律)

    莫比乌斯反演 血亏! 比赛时看到这题先写了个莫比乌斯反演,然后手造了几组数据和暴力对拍的时候发现,居然答案就是\(nm\)... 吐槽数据范围太小... 下面给上出题人对此题的解释: 原式的物理意义, ...