加入收藏 | 设为首页 | 会员中心 | 我要投稿 站长网 (https://www.51jishu.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

mysql checkpoint有什么用处

发布时间:2021-12-17 10:09:22 所属栏目:MySql教程 来源:互联网
导读:本篇内容主要讲解mysql checkpoint有什么作用,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习mysql checkpoint有什么作用吧! checkpoint检查点主要是刷新脏页到磁盘上,使数据库达到数据状态一致性的工作。因为
本篇内容主要讲解“mysql checkpoint有什么作用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“mysql checkpoint有什么作用”吧!
 
checkpoint检查点主要是刷新脏页到磁盘上,使数据库达到数据状态一致性的工作。因为事务的提交只会刷新操作日志到磁盘,脏数据是异步刷新到磁盘,这个异步就是靠checkpoint。
 
一、主要解决以下问题:
 
1、恢复的时候减少前滚操作,减少恢复时间
 
2、回收脏页,循环利用缓存池
 
3、重做日志不可用,刷新脏页
 
二、checkpoint种类及触发条件
 
sharp checkpoint (类似oracle全量)
 
当innodb_fast_shutdown=1和0时,数据库关闭时所有脏页全部刷新到磁盘上
 
Fuzzy checkpiont(类似oracle增量)
 
1、Master Thread进程每几秒或每十秒异步的将脏页一定比例的刷新到磁盘上
 
2、FlUSH_LUR_LIST checkpoint是因为在innodbmysql5.6版本以前需要保证LRU列表中需要有差不多100个空闲页可供使用,从mysql5.6版本以后,这个检查被放在一个单独的page cleaner线程中进行,而且用户可以通过参数innodb_lru_scan_depth控制LRU列表中可用页的数量,默认为1024
 
3、Async/Sync Flush checkpoint值重做日志文件不可用的时候
 
在重做日志文件不可用的情况下,需要将一些也刷新回磁盘,而操作发生在Flush列表上。若将已经写入到重做日志的LSN记为redo_lsn,将已经刷新回磁盘最新的LSN记为checkpoint_lsn,则可以定义:checkpoint_age = redo_lsn-checkpoint_lsn在定义一下的变量async_water_mark=75%*total_redo_log_file_size、sync_water_mark=90%*total_redo_file_size。若每个重做日志的大小为1G且定义了两个重做日志共2G。那么async_water_mark=1.5G,sync_water_mark=1.8G。
 
当checkpoint_age<async_water_mark时,不需要刷新任何脏数据到磁盘; </async_water_mark时,不需要刷新任何脏数据到磁盘;<>
 
当async_water_mark<checkpoint_age<sync_water_mark时,触发async flush从flush列表刷新足够的脏页会磁盘,使得刷新后满足checkpoint_age<async_water_mark; </checkpoint_age
 
当checkpoint_age>sync_water_mark时,这种情况很少发生除非设置的重做日志文件太小,并且进行类似于LOAD DATA的BULK INSRET操作。这个时候触发Sync Flush从Flush列表刷新足够的脏页会磁盘,使得刷新后满足checkpoint_age<async_water_mark; </async_water_mark;<>
 
Async Flush Checkpoint会阻塞发现问题的用户查询线程,Sync Flush Checkpoint会阻塞所有的用户查询线程,并且等待脏页刷新完成。但是从MySQL5.6版本开始这部分操作放入单独的Page Cleaner Thread中,不再会堵塞用户查询线程。
 
4、Dirty Page too much  当缓存池中的数据比例达到innodb_max_dirty_pages_pct比例时,强制checkpoint,刷新一部分脏页到磁盘上,innodb 1.0.X版本之前该参数默认是90,之后的版本都为75
 
mysql> show variables like 'innodb_max_dirty_pages_pct';
 
+----------------------------+-------+
 
| Variable_name              | Value |
 
+----------------------------+-------+
 
| innodb_max_dirty_pages_pct | 75    |
 
+----------------------------+-------+
 
1 row in set (0.00 sec)
 
到此,相信大家对“mysql checkpoint有什么作用”有了更深的了解,不妨来实际操作一番吧!这里是亿速云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

(编辑:站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!