脏页(内存页)干净页:内存和磁盘中的数据一致
脏页:内存和磁盘中的数据不一致
为什么会出现 脏页平时很快的更新操作,都是在写内存和日志。他并不会马上同步到磁盘数据页,这时内存数据页跟磁盘数据页内容不一致,我们称之为脏页。
这里面就涉及 mysql 的内存管理机制
内存管理机制简述缓冲区中包含这三大类列表。分别为:lrulist、freelist、flushlist。
在数据库刚启动时,lrulist中没有数据页。freelist存放空闲页。
当需要读取某个页时,会从freelist中获取一个空闲页,读入数据后,放入lrulist中
如果freelist中没有空闲页了,那么根据lru算法淘汰lru列表中末位的页
当lrulist中的页被修改后,页就变成了脏页,这个页也会被加入flushlist中
注意:这时这个页既在lrulist中,又在flushlist中。
总结:lrulist(管理已经被读取的页)和freelist(管理空闲的页)用来管理页的可用性;flushlist(管理脏页)用来管理脏页的刷新
在脏页数据同步到磁盘过程中,如果对该磁盘数据页执行 sql 语句。执行速度就会变慢
数据修改和读取只依赖缓冲区行不行假如只有缓存区用来进行数据修改和读取,一旦数据库宕机,缓存区中的数据将会丢失。因此,mysql利用之前介绍过的redo日志来实现在异常重启时的数据恢复。
以简单的方式解释,就是在更新缓冲区之前,将操作记录在redo log中,以确保在出现异常重启的情况下,仍然可以恢复缓冲区中的数据。
为什么脏页一定要刷新上面说了 数据只放在缓冲区,会出现数据库宕机,内存数据丢失。所以需要刷新到磁盘。
redo log如果无限大或者有许多个文件的话,系统中有大量的修改操作,一旦宕机,恢复的时间也会非常长。
所以自然而然,我们就一定需要把内存中的脏页按照某种规则刷新到磁盘中,有了刷新这个操作,缓冲区的大小问题和redo log的大小问题都可以解决。
缓冲区不需要无限大了,因为可以持久化到磁盘
因为一旦redo log中的数据被持久化到磁盘上,对应的部分数据就可以被释放,所以无需设置redo log过大。
刷脏页有下面4种场景undefined会造成的影响
如果是 redo log 写满了
要尽量避免redo log 写满。否则整个系统的更新都会停止。此时写的性能变为 0,必须等待该日志对应脏页同步完成后才能更新,这时就会导致 sql 语句 执行的很慢。
以上就是mysql脏页指的是什么的详细内容。
