• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    mysql脏页是什么

    脏页(内存页)

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

    为什么会出现 脏页

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

    内存管理机制简述

    缓冲区中包含这三大类列表。分别为:LRUList、FreeList、FlushList。
    在数据库刚启动时,LRUlist中没有数据页。FreeList存放空闲页。

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

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

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

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

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

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

    为什么脏页一定要刷新

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

    刷脏页有下面4种场景

    会造成的影响

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

     到此这篇关于mysql脏页是什么的文章就介绍到这了,更多相关mysql脏页内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

    您可能感兴趣的文章:
    • MySQL的Flush-List和脏页的落盘机制
    • Mysql脏页flush及收缩表空间原理解析
    上一篇:为什么MySQL分页用limit会越来越慢
    下一篇:使用ORM新增数据在Mysql中的操作步骤
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    mysql脏页是什么 mysql,脏页,是什么,mysql,脏页,