mysql脏页指的是什么

60次阅读
没有评论

共计 1364 个字符,预计需要花费 4 分钟才能阅读完成。

今天丸趣 TV 小编给大家分享一下 mysql 脏页指的是什么的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。

在 mysql 中,当内存数据页和磁盘数据页上的内容不一致时,则称这个内存页为脏页。刷脏页的场景:1、当 redo log 写满,mysql 就会暂停所有更新操作,将同步这部分日志对应的脏页同步到磁盘;2、系统内存不足时,需要淘汰一部分数据页,如果淘汰的是脏页,就要先将脏页同步到磁盘;3、MySQL 认为系统空闲的时候, 有机会就同步内存数据到磁盘,这种没有性能问题。

脏页(内存页)

干净页:内存和磁盘中的数据一致

脏页:内存和磁盘中的数据不一致

为什么会出现 脏页

平时很快的更新操作,都是在写内存和日志。
他并不会马上同步到磁盘数据页, 这时内存数据页跟磁盘数据页内容不一致, 我们称之为脏页。

这里面就涉及 mysql 的内存管理机制

内存管理机制简述

缓冲区中包含这三大类列表。分别为:LRUList、FreeList、FlushList。

在数据库刚启动时,LRUlist 中没有数据页。FreeList 存放空闲页。

当需要读取某个页时,会从 FreeList 中获取一个空闲页,读入数据后,放入 LRUlist 中

如果 FreeList 中没有空闲页了,那么根据 LRU 算法淘汰 Lru 列表中末位的页

当 LRUlist 中的页被修改后,页就变成了脏页,这个页也会被加入 FlushList 中

注意:这时这个页既在 LRUlist 中,又在 FlushList 中。

总结:LRUList(管理已经被读取的页)和 FreeList(管理空闲的页)用来管理页的可用性;FlushList(管理脏页)用来管理脏页的刷新

在脏页数据同步到磁盘过程中,如果对该磁盘数据页执行 SQL 语句。执行速度就会变慢

数据修改和读取只依赖缓冲区行不行

如果数据修改和读取只依赖内存的缓冲区,那么一旦数据库宕机,内存中的数据都会丢失。所以 MySQL 使用之前讲过的 redo log 来实现异常重启的数据恢复。

简单来说,就是在更新缓冲区之前,先写入 redo log,保证异常重启之后可以正常恢复缓冲区中的数据。

为什么脏页一定要刷新

上面说了 数据只放在缓冲区,会出现数据库宕机,内存数据丢失。所以需要刷新到磁盘。

redo log 如果无限大或者有许多个文件的话,系统中有大量的修改操作,一旦宕机,恢复的时间也会非常长。

所以自然而然,我们就一定需要把内存中的脏页按照某种规则刷新到磁盘中,有了刷新这个操作,缓冲区的大小问题和 redo log 的大小问题都可以解决。

缓冲区不需要无限大了,因为可以持久化到磁盘

redo log 也不需要无限大了,因为一旦持久化到磁盘,redo log 中对应的那部分数据就可以释放。

刷脏页有下面 4 种场景

undefined 会造成的影响

如果是 redo log 写满了

要尽量避免 redo log 写满。否则整个系统的更新都会停止。此时写的性能变为 0,必须等待该日志对应脏页同步完成后才能更新, 这时就会导致 sql 语句 执行的很慢。

以上就是“mysql 脏页指的是什么”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,丸趣 TV 小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注丸趣 TV 行业资讯频道。

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-07-13发表,共计1364字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)