MySQL--Checkpoint基础
=====================================================
Checkpint 分两种:
Sharp Checkpoint : 在服务器正常关闭时,将所有脏页都写入到磁盘中,默认配置参数 innodb_fast_shutdown=1
Fuzzy Checkpoint: 在服务正常运行过程中,由各种条件触发进行Fuzzy Checkpoint, 只将部分脏页刷新写入到磁盘中。
=====================================================
触发Fuzzy Checkpoint的可能情况:
1> Master Thread Checkpoint
2> FLUSH_LRU_LIST Checkpoint
3> Async/Sync Flush Checkpoint
4> Dirty Page Too Much Checkpoint
=====================================================
Master Thread Checkpoint
Master Thread 会以一定频率(每秒或每10秒)从缓冲池的脏页列表中刷新一定比例的页到磁盘中,该操作为异步模式,不会阻塞用户查询。
=====================================================
FLUSH_LRU_LIST Checkpoint
由于InnoDB存储引擎需要保证LRU列表中有一定数量的空闲页空使用,当FLUSH_LRU_LIST列表中没有足够的空闲页时,InnoDB会将LRU列表尾部的页移除,,如果要移除的数据页中有脏页,就需要进行checkpoint将数据写入到磁盘上。
在Innodb 1.1.x 版本前,检查FLUSH_LRU_LIST列表的操作在用户线程中执行,因此checkpoint操作会阻塞用户查询操作
在Innodb 1.1.x 版本后,检查FLUSH_LRU_LIST列表的操作在独立线程Page Cleaner中执行,因此checkpoint操作不会阻塞用户查询操作
在Innodb 1.2.x 版本前,FLUSH_LRU_LIST列表控制在100个空闲页可用。
在Innodb 1.2.x 版本后,用户可用通过参数innodb_lru_scan_depth来控制列表可用页的数量,该参数默认值为1024.
=====================================================
Async/Sync Flush Checkpoint
Async/Sync Flush Checkpoint为了保证重做日志的循环使用的可用性,根据最近一次checkoint和当前redo lsn计算出checkpoint_page 数,再按照checkpoint_page 数占重做日志空间的比例来选择进行Async/Sync Flush Checkpoint。
checkpoint_page =redb_lsn - checkpoint_lsn
async_water_mark =75%* total_redo_log_file_size
sync_water_mark =90%* total_redo_log_file_size
当checkpoint_page<async_water_mark时,不需要刷新任何脏页到磁盘
当async_water_mark<checkpoint_page <sync_water_mark 时,使用async flush checkpoint 将脏页数据写入到磁盘中
当checkpoint_page >sync_water_mark 时,使用 sync flush checkpoint 将脏页数据写入到磁盘中
在Innodb 1.2.X版本前,Async Flush Checkpoint操作会阻塞发现问题的用户线程查询,Sync Flush Checkpoint 会阻塞所有用户的查询线程。
在Innodb 1.2.X版本后,这两类checkpoint 操作被放入到Page Cleaner Thread中,故不会阻塞用户查询线程。
=====================================================
Dirty Page Too Much Checkpoint
为保障缓冲池有足够可用的页,当脏页数量到达缓冲池特定比例的时候,会导致Innodb存储引擎强制进行check point, 该比例由参数innodb_max_dirty_page_pct控制:
show variables like 'innodb_max_dirty_pages_pct' \G
*************************** 1. row ***************************
Variable_name: innodb_max_dirty_pages_pct
Value: 75
1 row in set (0.00 sec)
在innodb 1.0.x 版本之前,该默认值为90,在innodb 1.0.x 版本之后,默认值为75
=====================================================
Undo 日志在Checkpoint时会写入磁盘。
MySQL--Checkpoint基础的更多相关文章
- 高性能MySQL之基础架构
一.背景 为什么我们需要先学习MYSQL的基础架构先呢? 原因很简单,当我们需要了解一件事物的时候,我们只有站在宏观的层面,才能层层剥丝抽茧的去理解问题.举个例子,我们要看一个框架的源码,一开始就想进 ...
- mysql使用基础 sql语句(一)
csdn博文地址:mysql使用基础 sql语句(一) 点击进入 命令行输入mysql -u root -p,回车再输入密码,进入mysql. 终端命令以分号作为一条语句的结束,可分为多行输入,只需 ...
- mysql数据库基础的简单操作指南
最近在学习mysql,本文是做的关于mysql学习的笔记,跟大家分享一下,希望对大家学习mysql知识有所助益.mysql现在几乎已经成了网站建设的主流数据库,很多php网站系统都采用了mysql数据 ...
- Mysql索引基础
Mysql索引基础 基本概念: 索引是一种特殊的数据库结构,可以用来快速查询数据库表中的特定记录.索引是提高数据库性能的重要方式.索引创建在表上,是对数据库表中一列或多列的值进行排序的一种结构.可以提 ...
- MySQL数据库基础
MySQL数据库基础 本文的所有操作是基于CMD环境,MySQL通过在命令行中输入SQL语句对数据库进行操作.配置问题可参考<打通MySQL的操作权限>中的内容,该文算是针对前期的环境配置 ...
- Mysql数据库基础学习笔记
Mysql数据库基础学习笔记 1.mysql查看当前登录的账户名以及数据库 一.单表查询 1.创建数据库yuzly,创建表fruits 创建表 ) ) ,) NOT NULL,PRIMARY KEY( ...
- 2.Mysql SQL基础
2.Mysql SQL基础2.1 SQL简介 SQL(Structure Query Language)是结构化查询语言.2.2 SQL使用入门 2.2.1 SQL分类 SQL分为DDL.DML(DQ ...
- 【笔记】MySQL的基础学习(二)
[笔记]MySQL的基础学习(二) MySQL 老男孩 一 视图 视图其实就是给表起个别名 1.创建视图 格式:CREATE VIEW 视图名称 AS SQL语句 CREATE VIEW v1 AS ...
- 【笔记】MySQL的基础学习
[笔记]MySQL的基础学习 老男孩 MySQL 一 安装与配置 1 下载安装 官网:http://dev.mysql.com/downloads/mysql/ 下载相应版本的压缩包 解压压缩包至任 ...
- MySQL学习——基础
本文是MySQL的基础知识. Linux启动MySQL服务命令 : service mysql start Linux关闭MySQL服务命令 : service mysql stop 登录MySQL命 ...
随机推荐
- vue-12-渲染函数 & JSX
render() Vue.component('anchored-heading', { render: function (createElement) { return createElement ...
- Linux如何产看系统信息
如何查看已安装的CentOS版本信息: 1)[root@localhost ~]# cat /proc/version Linux version 2.6.18-194.el5 (mockbuild@ ...
- 浅议APC
0x01 APC中断请求级别 在Intel x86体系结构中,外部硬件中断是通过处理器上的"中断管脚"或者一个称为"本地APIC(local APIC)" ...
- Java实验2
1.给定一组字符,编程输出里面数值最大者. package experiment; import java.util.Arrays; public class ShenYue { public sta ...
- Centos7部署kubectl命令行工具(五)
1.准备二进制包 [root@linux-node1 ~]# cd /usr/local/src/kubernetes/client/bin [root@linux-node1 bin]# cp ku ...
- Java进程和线程
进程是资源分配和任务调度的基本单位, 进程就是包含上下文切换的程序执行时间总和=CPU加载上下文环境+CPU执行+CPU保存上下文环境,可以理解为时间片段: 进程的颗粒度太大了,将进程分块,按照a,c ...
- spoon 更新数据
一个小需求,被要求使用spoon 来同步数据 主要流程为: 1.查询A库未同步数据 id 2.根据步骤1查到的id,作为条件更新B库数据 3.更新B库数据成功则更改库A中的数据状态为已同步. 4.添加 ...
- Linux平台搭建-----C语言
下面内容是新手上路,各位高手路过勿喷!因为我第一次发布,可能页面设置或者其他做的不好,还请见谅~该文章只是作为我学习C语言的笔记以及记录学习进程的. 零基础学习C语言---搭建Linux平台开发环境 ...
- 20165214 学习基础与C语言基础调查
读后感 我花时间仔细阅读了娄老师公众号上的那5篇关于自己各个方面学习经历的文章,随后深为震撼又自愧不如. 我实在没想到,这套学习方法竟有如此巨大的力量!纵使在娄老师不熟悉的乒乓球领域,娄老师也能通过这 ...
- TDate赋值给Variant时注意的问题
//Delphi 10.3.1 32bit, Win 7 32bit procedure TForm1.btnTimeToVariantClick(Sender: TObject); var d:TD ...