【MySQL】日志缓冲区详解 以及 InnoDB内存结构总结

📢博客主页:https://blog.csdn.net/2301_779549673

📢博客仓库:https://gitee.com/JohnKingW/linux_test/tree/master/lesson

📢欢迎点赞 👍 收藏 ⭐留言 📝 如有错误敬请指正!

📢本文由 JohnKi 原创,首发于 CSDN🙉

📢未来很长,值得我们全力奔赴更美好的生活✨

文章目录


前些天发现了一个巨牛的 人工智能学习网站 ,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到 网站


🏳️‍🌈一、日志缓冲区的作用?

日志缓冲区 是服务器启动时向操作系统申请的一片连续的内存区域,存储即将要写入磁盘日志文件的数据。

在对数据库进行 DML 操作时,InnoDB 会记录对应操作的日志,比如为保证数据完整性实现数据库崩溃恢复的 Redo Log,这些日志会首先写入 Log Buffer 中,从而解决同步写磁盘导致的性能问题然后根据不同落盘策略最终写入磁盘

🏳️‍🌈二、日志不通过Log Buffer直接写入磁盘不行吗?

如果日志不通过 Log Buffer 直接写入磁盘,那么每次进行 DML 操作都会进行一次磁盘I/0,这样会严重影响效率,所以把日志统一写入内存中的LogBuffer,根据刷盘策略统一进行落盘操作,可以实现一次磁盘I/0写入多条日志,从而提升效率

🏳️‍🌈三、InnoDB内存结构总结

InnoDB内存结构主要分为:

  • Buffer Pool 缓冲池、
  • Change Buffer 变更缓冲区
  • adaptive_hash_index 自适应哈希索引。
  • Log Buffer 日志缓冲区。

缓冲池

  • 内存中的主要工作区域。
  • 缓冲池中包含至少一个 Instances,每个 Instances 中包含至少一个 CChunkChunk 管理着多个数据页
  • 缓冲池中使用控制块与数据页建立对应关系,通过双向链表连接每个控制块,从而管0理数据页
  • 缓冲池中有三个链表分别是 Free List、LRU List 和 Flush List:。
    • Free List: 只管理 Free 页
    • LRU List: 管理 Clean 页和 Dirty 页
    • Flush List: 只管理 Dirty 页
  • 缓冲池淘汰策略采用变形的最近最少使用算法LRU。

变更缓冲区

用来缓存对二级索引数据的修改,从而减少磁盘的10次数以提升效率。

自适应哈希索引

为频繁使用的查询条件和对应的数据页建立映射关系,从而提升内存级别的查询效率

日志缓冲区

把日志统一写入内存中的 Log Buffer,根据刷盘策略统一进行落盘操作,从而减少磁0盘的10次数以提升效率


👥总结

本篇博文对 【MySQL】日志缓冲区详解 以及 InnoDB内存结构总结 做了一个较为详细的介绍,不知道对你有没有帮助呢

觉得博主写得还不错的三连支持下吧!会继续努力的~

相关推荐
forestsea2 分钟前
MySQL 入门大全:数据类型
数据库·mysql
Dreams°1233 分钟前
【Python爬虫 !!!!!!政府招投标数据爬虫项目--医疗实例项目文档(提供源码!!!)!!!学会Python爬虫轻松赚外快】
分布式·爬虫·python·mysql·scikit-learn
为自己_带盐30 分钟前
浅聊一下数据库的索引优化
开发语言·数据库·php
gb42152871 小时前
mysql数据库中某个数据表的碎片率自己降低了,mysql数据表对碎片率有自动优化机制吗?
数据库·mysql
AI大模型顾潇1 小时前
[特殊字符] 本地大模型编程实战(29):用大语言模型LLM查询图数据库NEO4J(2)
前端·数据库·人工智能·语言模型·自然语言处理·prompt·neo4j
有时间要学习1 小时前
MySQL——数据类型&&表的约束
数据库·mysql
AI改变未来2 小时前
数据库常见故障排查
数据库
bing_1582 小时前
MongoDB 的核心概念(文档、集合、数据库、BSON)是什么?
数据库·mongodb·oracle
feilieren2 小时前
Windows 安装 Milvus
数据库·ai·milvus
kngines2 小时前
【PostgreSQL数据分析实战:从数据清洗到可视化全流程】附录-D. 扩展插件列表(PostGIS/PostgREST等)
数据库·postgresql·数据分析·pgvector·扩展插件·postgrest·向量数据