iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >mysql脏页是什么
  • 187
分享到

mysql脏页是什么

mysql脏页 2022-05-12 17:05:23 187人浏览 泡泡鱼
摘要

目录脏页(内存页)为什么会出现 脏页内存管理机制简述数据修改和读取只依赖缓冲区行不行为什么脏页一定要刷新刷脏页有下面4种场景会造成的影响脏页(内存页) 干净页:内存和磁盘中的数据一致 脏页:内存和磁盘中的数据不一致

目录
  • 脏页(内存页)
  • 为什么会出现 脏页
    • 内存管理机制简述
    • 数据修改和读取只依赖缓冲区行不行
  • 为什么脏页一定要刷新
    • 刷脏页有下面4种场景
      • 会造成的影响

        脏页(内存页)

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

        为什么会出现 脏页

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

        内存管理机制简述

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

        • 当需要读取某个页时,会从FreeList中获取一个空闲页,读入数据后,放入LRUlist中
        • 如果FreeList中没有空闲页了,那么根据LRU算法淘汰Lru列表中末位的页
        • 当LRUlist中的页被修改后,页就变成了脏页,这个页也会被加入FlushList中

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

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

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

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

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

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

        为什么脏页一定要刷新

        • 上面说了 数据只放在缓冲区,会出现数据库宕机,内存数据丢失。所以需要刷新到磁盘。
        • redo log如果无限大或者有许多个文件的话,系统中有大量的修改操作,一旦宕机,恢复的时间也会非常长。

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

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

        刷脏页有下面4种场景

        • 当 redo log 写满,mysql就会暂停所有更新操作,将同步这部分日志对应的脏页同步到磁盘。
        • 系统内存不足时,需要淘汰一部分数据页,如果淘汰的是脏页,就要先将脏页同步到磁盘。
        • MySQL 认为系统空闲的时候,有机会就同步内存数据到磁盘,这种没有性能问题。
        • MySQL 正常关闭,MySQL 会把内存的脏页都同步到磁盘上,这样下次 MySQL 启动的时候,就可以直接从磁盘上读数据,启动速度会很快。这种没有性能问题。

        会造成的影响

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

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

        您可能感兴趣的文档:

        --结束END--

        本文标题: mysql脏页是什么

        本文链接: https://www.lsjlt.com/news/10464.html(转载时请注明来源链接)

        有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

        本篇文章演示代码以及资料文档资料下载

        下载Word文档到电脑,方便收藏和打印~

        下载Word文档
        猜你喜欢
        • mysql脏页指的是什么
          今天小编给大家分享一下mysql脏页指的是什么的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧...
          99+
          2023-05-25
          mysql
        • 什么是脏读与幻读
          这篇文章主要讲解了“什么是脏读与幻读”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“什么是脏读与幻读”吧!select @@tx_isol...
          99+
          2024-04-02
        • mysql脏读和幻读的区别是什么
          MySQL中的脏读(Dirty Read)是指一个事务在未提交前读取了另一个事务尚未提交的数据。而幻读(Phantom Read)则...
          99+
          2023-08-19
          mysql
        • mysql怎么解决脏读
          脏读是指一个事务读取了另一个事务尚未提交的数据。为了解决脏读问题,可以采用以下几种方法:1. 采用事务隔离级别:将事务隔离级别设置为...
          99+
          2023-08-23
          mysql
        • PostgreSQL checkpoint中用于刷一个脏page的函数是什么
          这篇文章主要讲解了“PostgreSQL checkpoint中用于刷一个脏page的函数是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Postgre...
          99+
          2024-04-02
        • mysql数据库事务隔离级别及脏读、不可重复读、幻读是什么
          mysql数据库事务隔离级别及脏读、不可重复读、幻读是什么?这个问题可能是我们日常学习或工作经常见到的。希望通过这个问题能让你收获颇深。下面是小编给大家带来的参考内容,让我们一起来看看吧!一、数据库事务正确...
          99+
          2024-04-02
        • 什么是网页
          网页是网站中的一页,通常是HTML格式的文件,主要通过浏览器来阅读。,它是构成网站的基本元素,通常由图片、链接、文字、视频等元素组成,因此俗称为HTML文件。...
          99+
          2024-04-02
        • MySQL中InnoDB数据页的原理是什么
          MySQL中InnoDB数据页的原理是什么,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。不同类型的页简介它是InnoDB管理存储空间的基本单位...
          99+
          2024-04-02
        • mysql limit分页实现的方法是什么
          MySQL中的LIMIT语句用于限制查询结果的数量。它的基本语法如下: SELECT column1, column2, ....
          99+
          2024-04-09
          mysql
        • Mysql执行count出现脏读问题怎么解决
          这篇文章主要介绍“Mysql执行count出现脏读问题怎么解决”,在日常操作中,相信很多人在Mysql执行count出现脏读问题怎么解决问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大...
          99+
          2024-04-02
        • mysql分页查询优化的方法是什么
          MySQL分页查询的优化方法包括:1. 使用索引:在进行分页查询时,使用合适的索引可以大大提高查询性能。可以创建适当的索引,以确保查...
          99+
          2023-10-08
          mysql
        • MySQL实现数据分页的方法是什么
          MySQL实现数据分页的方法通常是使用LIMIT子句。通过在查询语句中使用LIMIT子句,可以限制返回的数据行数,并可以指定返回数据...
          99+
          2024-04-09
          MySQL
        • mysql大数据分页优化的方法是什么
          在处理大数据分页时,可以通过以下方法来优化MySQL数据库的性能: 使用索引:为查询条件中经常使用的字段添加索引,可以加快查询速...
          99+
          2024-04-09
          mysql
        • mysql数据库分页查询的方法是什么
          MySQL数据库分页查询的方法是使用LIMIT关键字来限制查询结果的返回行数。LIMIT子句可以在SELECT语句中使用,其...
          99+
          2023-08-30
          mysql数据库
        • phpcms列表页是什么
          phpcms列表页是指用于显示网站文章、产品、图片等内容列表的页面。列表页一般由多个列表项组成,每个列表项对应着一个具体的内容。列表项通常包含标题、发布时间、缩略图等信息,并可以通过点击进入详细内容页。通过列表页可以方便地展示和导航网站的各...
          99+
          2023-07-13
        • oracle中什么是分页
          oracle中的分页是一种用于检索数据库结果集的技术, 通过将结果集分割成较小的块来减少网络传输和内存消耗,使用“ROWNUM”关键字和子查询,程序员可以轻松地实现分页功能,并根据用户的需求选择特定的数据块显示。本教程操作环境:window...
          99+
          2023-08-07
        • 什么是vue单页面和多页面
          本教程操作环境:windows7系统、vue3版,DELL G3电脑。vue中什么是单页面和多页面单页:全称SPA单页面应用(SinglePage Web Application)。单页应用将所有内容放在一个页面中,从而使整个页面更加流畅。...
          99+
          2023-05-14
          Vue vue.js
        • 什么是MySQL
          本篇内容主要讲解“什么是MySQL”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“什么是MySQL”吧!MySQL 是最流行的关系型数据库管理系统,在 WEB 应...
          99+
          2024-04-02
        • vue单页面和多页面是什么
          本文小编为大家详细介绍“vue单页面和多页面是什么”,内容详细,步骤清晰,细节处理妥当,希望这篇“vue单页面和多页面是什么”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。在vue中,单页面全称“SPA单页面应用”...
          99+
          2023-07-04
        • MySQL分页存储过程的实现原理是什么
          MySQL分页存储过程的实现原理是通过使用存储过程来动态生成分页查询语句,实现分页功能。存储过程是一组预先编译好的SQL语句组成的代...
          99+
          2024-04-09
          MySQL
        软考高级职称资格查询
        编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
        • 官方手机版

        • 微信公众号

        • 商务合作