MySQL 基础知识梳理学习(三)----InnoDB日志相关的几个要点
1.InnoDB的特点 :(1)Fully ACID (InnoDB默认的Repeat Read隔离级别支持);(2)Row-level Locking(支持行锁);(3)Multi-version concurrency control (MVCC 支持多版本控制);(4)Foreign key support (支持外键);(5)Automatic deadlock detection(死锁自动检测);(6)High performance、High scalability、High availablility(高性能、高扩展、高可用)。
2.InnoDB的文件主要分为两个部分,一个是表空间文件,一个是重做日志文件。表空间文件包含独立表空间文件、全局表空间文件和Undo表空间文件。重做日志文件就是物理逻辑日志。
3.REDO LOG 是用来做数据库crash recovery的,是保证数据库数据正确性、完整性及持久性的重要机制之一。在数据库操作中,它保存了对InnoDB表中数据的修改记录,所以也叫日志文件。
4.日志文件内部也是按照大小相等的页面切割,页面大小为512个字节(回顾下数据页是多大? )。考虑到机械硬盘的块大小也是512字节,所以日志块也是如此设计。
解释:这是因为写日志其实就是为了提高数据库写入吞吐量,如果每次写入是磁盘块大小的倍数,效率才是最高的,并且日志将逻辑事务对数据库的分散随机写入转化成了顺序的512字节整倍数据的写入,这样就大大提高了数据库的效率。
5.物理事务(Mini-transaction ,MTR)是相对逻辑事务而言的。(逻辑事务具有ACID四个特性,用来保证数据库的完整性--要么都做,要么什么都不做。)物理事务是对InnoDB存储引擎而言的,在存储引擎中,只要涉及到文件修改、文件读取等物理操作,都离不开这个物理事务,可以说,物理事务是Buffer Pool中Page与文件中的一个桥梁。
6.InnoDB的REDO日志不完全是物理日志,它包含了部分逻辑意义。比如,插入一条记录时,MTR记录的是在一个页面中写入这条记录,内容大致包括页面号、文件号(表空间号)、以及这条记录的值(包括每个列信息),这样就有了逻辑概念。
7.一个逻辑事务由多个物理事务组成,用来保证数据库的ACID特性。物理事务可以保证一次物理修改是完整的,即可以理解为一个底层的相对完整的操作。比如,在插入一条记录的过程中,会包括写一条回滚记录及插入时写入一个页面等,那么这些逻辑上是一个动作的物理写入,就可以被认为是一个独立的物理事务。
8.物理事务的作用过程:首先,在系统将一个页面载入Buffer Pool时,需要一个新开始(mtr_start)或者一个已将开始的物理事务,载入时需要指定页面的获取方式,比如是用来读取的还是用来修改的,根据获取方式上锁(写,则上X锁;读,上S锁),上锁前,还需进行检查,例如是否页面已被上锁,是否需要排队等待等 。然后,当上锁成功后,物理事务就会将这个页面的内存结构存储到memo动态数组中,然后这个物理事务就可以访问这个页面了。物理事务对页面的访问有两种操作,一种是读,另一种是写。读操作就是简单读取指定页面内偏移及长度的数据。写则是指定从某一偏移开始写入指定长度的数据。同时,如果这个物理事务是写日志的,此时还需要对刚才的写操作记下日志。最后,是物理事务的提交,主要是将这个物理事务产生的日志写入到InnoDB日志系统的日志缓冲区中,然后,等待时机(日志刷盘机制),将缓冲区中的日志数据刷到日志文件中。
9.日志缓冲区的存储只是一个暂时的中间状态,日志缓冲区的大小可以通过参数innodb_log_buffer_size来设置。
10.日志产生的作用,是将随机页面写入变成顺序日志的写入,从而用一个速度更快的写入来保证速度较慢的写入的完整性,已提高整体数据的性能。
11.REDO 日志恢复 主要过程:(1)从日志文件的固定位置找到最新的检查点信息;(2)从最新的检查点位置开始扫描日志文件,做数据库恢复。
12.InnoDB的REDO是在UNDO之前做的,是等到物理的数据库操作都完成之后,才能在物理数据一致的基础上去做一些逻辑的操作,即UNDO回滚操作。
-----主要部分内容参考梳理于网络知识,此仅为学习笔记,在此原创作者感谢!
MySQL 基础知识梳理学习(三)----InnoDB日志相关的几个要点的更多相关文章
- MySQL 基础知识梳理学习(五)----详解MySQL两次写的设计及实现
一 . 两次写提出的背景或要解决的问题 两次写(InnoDB Double Write)是Innodb中很独特的一个功能点.因为Innodb中的日志是逻辑的,所谓逻辑就是比如插入一条记录时,它可能会在 ...
- MySQL 基础知识梳理学习(七)----sync_binlog
一般在生产环境中,很少用MySQL单实例来支撑业务,大部分的MySQL应用都是采用搭建集群的方法.搭建MySQL集群,可以进行数据库层面的读写分离.负载均衡或数据备份.基于MySQL原生的Replic ...
- MySQL 基础知识梳理学习(四)----GTID
在日常运维中,GTID带来的最方便的作用就是搭建和维护主从复制.GTID的主从模式代替了MySQL早期版本中利用二进制日志文件的名称和日志位置的做法,使用GTID使操作和维护都变得更加简洁和可高. 1 ...
- MySQL 基础知识梳理学习(二)----记录在页面层级的组织管理
1.InnoDB的数据存储结构 InnoDB中数据是通过段.簇.页面构成的. (1)段是表空间文件中的主要组织结构,它是一个逻辑概念,用来管理物理文件,是构成索引.表.回滚段的基本元素.创建一个索引( ...
- MySQL 基础知识梳理学习(六)----锁
1.什么是锁: 对共享资源进行并发访问控制,提供数据的完整性和一致性. 2.锁的区别: 类型 lock latch 对象 事务 线程 保护 数据库内容 内存数据结构 持续时间 整个事务过程 临界资源 ...
- MySQL 基础知识梳理学习(五)----半同步复制
1.半同步复制的特征 (1)从库会在连接到主库时告诉主库,它是不是配置了半同步. (2)如果半同步复制在主库端是开启了的,并且至少有一个半同步复制的从节点,那么此时主库的事务线程在提交时会被阻塞并等待 ...
- MySQL 基础知识梳理学习(一)----系统数据库
information_schema 此数据库是MySQL数据库自带的,主要存储数据库的元数据,保存了关于MySQL服务器维护的所有其他数据库的信息,如数据库名.数据库表.表列的数据类型及访问权限等. ...
- MySQL 基础知识梳理
MySQL 的安装方式有多种,但是对于不同场景,会有最适合该场景的 MySQL 安装方式,下面就介绍一下 MySQL 常见的安装方法,包括 rpm 安装,yum 安装,通用二进制安装以及源码编译安装, ...
- [SQL] SQL 基础知识梳理(三) - 聚合和排序
SQL 基础知识梳理(三) - 聚合和排序 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5926689.html 序 这是<SQL 基础知识梳理 ...
随机推荐
- [Swift]LeetCode423. 从英文中重建数字 | Reconstruct Original Digits from English
Given a non-empty string containing an out-of-order English representation of digits 0-9, output the ...
- [Swift]LeetCode983. 最低票价 | Minimum Cost For Tickets
In a country popular for train travel, you have planned some train travelling one year in advance. ...
- HBase之CF持久化系列(续2)
正如上篇博文所说,在本节我将为大家带来StoreFlusher.finalizeWriter..如果大家没有看过我的上篇博文<HBase之CF持久化系列(续1)>,那我希望大家还是回去看一 ...
- Java 子类 instanceof 父类
1.结论: 子类 instanceof 父类 == true 父类 instanceof 子类 == false 2.测试代码 @Test public void testInstanceof() { ...
- System.Data.Entity.Infrastructure.DbUpdateException
异常描述: 捕捉到 System.Data.Entity.Infrastructure.DbUpdateException HResult=-2146233087 Message=无法更新 E ...
- 纽约工作日志流水账 Day 1
周六早上8:00从青岛登机,历经17个小时,终于在当地时间周六下午2点半到达目的地纽约. 被媳妇吐槽旁边坐了美女妹子,其实是个美国妹子,旁边人家还有男朋友,全程只和我说了2句话,Exc ...
- 面试 Linux 运维工作至少需要知道哪些知识?
前言 我们已经发过不少 Linux 面试题,但是单独的面试题总感觉会过于零碎,没有体系化内容给人的帮助大. 知乎上有这样一个问题:一个新手面试 Linux 运维工作至少需要知道哪些知识?其中有一个答案 ...
- 前端笔记之jQuery(上)加载函数的区别&对象&操作HTML/CSS&动画&选择器
一.jQuery简介 1.0 JavaScript编程比较恶心的地方 恶心1:选择元素麻烦,全线兼容的方法只有getElementById()和getElementsByTagName()两个.其他的 ...
- Asp.Net Core与携程阿波罗(Apollo)的第一次亲密接触
一.瞎扯点什么 1.1 阿波罗 阿波罗是希腊神话中的光明之神.文艺之神,同时也是罗马神话中的太阳神:他是光明之神,从不说谎,光明磊落,在其身上找不到黑暗,也被称作真理之神.他非常聪明,通晓世事,是 ...
- 【ASP.NET Core快速入门】(六)配置的热更新、配置的框架设计
配置的热更新 什么是热更新:一般来说,我们创建的项目都无法做到热更新:即项目无需重启,修改配置文件后读取到的信息就是修改配置之后的 我们只需要吧项目中用到的IOptions改成IOptionsSnap ...