mysql innodb存储原理(mysql innodb的重要组件汇总)
mysql innodb存储原理
mysql innodb的重要组件汇总innodb包涵如下几个组件
一、innodb_buffer_pool:
它主要用来缓存数据与索引(准确的讲由于innodb中的表是由聚集索引组织的,所以数据只不是过主键这个索引的叶子结点)。
二、change buffer:
1 如果更新语句要更新二级索引的记录,但是记录所在的页面这个里面并没有在innodb_buffer_pool中,innodb会把这个对二级索引
面页的更新动作缓存到innodb_buffer_pool的一个特定区域(change buffer);等到之后如果有别的事务B要去读这个二级索引页的时候,
由于页面还没有,在innodb_buffer_pool中所以B事务会先把页面载入innodb_buffer_pool,这样子目标页面就算进入innodb_buffer_pool了,
接下来就可根据change buffer的内容来更新索引页面了。这样可以节约IO操作,提高性能。
2 当然别的刷新机(把change buffer中的变更落盘)制也是有的,比如说当mysql比较空闲的时候,slow shutdown 的过程当中也会刷新
change buffer中的内容到磁盘
3 监控change buffer
|
show engine innodb status; ------------------------------------- INSERT BUFFER AND ADAPTIVE HASH INDEX ------------------------------------- Ibuf: size 1, free list len 0, seg size 2, 0 merges merged operations: insert 0, delete mark 0, delete 0 discarded operations: insert 0, delete mark 0, delete 0 Hash table size 34679, node heap has 0 buffer(s) Hash table size 34679, node heap has 0 buffer(s) Hash table size 34679, node heap has 0 buffer(s) Hash table size 34679, node heap has 0 buffer(s) Hash table size 34679, node heap has 0 buffer(s) Hash table size 34679, node heap has 0 buffer(s) Hash table size 34679, node heap has 0 buffer(s) Hash table size 34679, node heap has 0 buffer(s) 0.00 hash searches/s, 0.00 non-hash searches/s --- LOG --- Log sequence number 24635311 Log flushed up to 24635311 Pages flushed up to 24635311 Last checkpoint at 24635302 0 pending log flushes, 0 pending chkp writes 10 log i/o 's done, 0.00 log i/o' s/ second |
三、自适应hash索引:
1 如果表中的某些行会非常频繁的用到,由于innodb表是B+树组织起来的这一特性,最好的情况下innodb也是先读索引页,再读数据页,然后
找到数据;hash索引是用B+树索引的hash为键,以B+树索引的值(指向的页面)为值的;由于有了hash索引的引入,innodb可以通过计算索引的hash
值就直接定位到数据所在的页面;所以对于非范围查找的情况下hash索引这样的处理方式是有优势的。
2 要想innodb能用上bash索引还要有几个条件1、innodb_adaptive_hash_index=1 这样innodb就会启用hash索引了;然而这只是完成了一半,
innodb并不是为表中的所有行建立hash索引的,只是表中频繁访问的行才会为它建立hash索引,为冷数据建立hash索引是一种浪费;
innodb_adaptive_hash_index_parts 可以设置hash索引的分区,这种可以提升并发度。
四、redo log buffer:
redo log buffer 中的内容会被定期的刷新到磁盘,如果redo log buffer 设置的比较大它有利于mysql对大事务的处理,原因在于在大事务的处理中
可以把redo 写入到redo log buffer 而不是写入到磁盘,由于内存比磁盘快,所以大事务的处理速度上也会比较快;也就是说redo log buffer 比较大
的情况下在commit 之前可以减少一些没有必要的刷磁盘操作。
五、系统表空间:
innodb 系统表空间中包涵如下内容:innodb 数据字典,一些存储区域如 doublewrite\changebuffer\undolog ,如果innodb_file_per_table
没有打开那么那么用户建的表就会保存到这个系统表空间中,这种情况下系统表空间也就可以看面它包涵共享表空间了。
以上就是mysql innodb的重要组件汇总的详细内容,更多关于mysql innodb组件的资料请关注开心学习网其它相关文章!
原文链接:https://www.cnblogs.com/JiangLe/p/7117576.html
- 怎样查看mysql的安装路径(MySQL中查看数据库安装路径的方法)
- mysql允许远程访问docker(Docker部署mysql远程连接 解决2003的问题)
- mysql中的null是什么(浅谈为什么Mysql数据库尽量避免NULL)
- mysql时间戳和datetime对比(mysql中 datatime与timestamp的区别说明)
- mysql innodb存储原理(mysql innodb的重要组件汇总)
- 如何重新配置mysql的端口(如何快速修改MySQL用户的host属性)
- mysql 快速迁移到历史表(MySQL 线上日志库迁移实例)
- mysql哪些配置影响性能
- mysql长连接释放和不释放的问题(解决MySQL存储时间出现不一致的问题)
- centos如何安装mysql8.0版本(Centos7下安装MySQL8.0.23的步骤小白入门级别)
- mysql存储引擎的创建与修改(关于MySQL Memory存储引擎的相关知识)
- phpstudymysql数据库启动不了(phpstudy mysql启动不了的解决方法)
- mysql数据库下载安装步骤(MySQL数据库压缩版本安装与配置详细教程)
- 将SQL Server数据迁移到MySQL的方法
- python mysql配置(详解python校验SQL脚本命名规则)
- MySQL主从状态检查的实现(MySQL主从状态检查的实现)
- 雄藩崛起 奇兵队与幕末长州藩军事改革(雄藩崛起奇兵队与幕末长州藩军事改革)
- 九月初,爱如蜜糖,甜到心扉,迷恋彼此,一日不见兮,思之若狂(九月初爱如蜜糖)
- ()
- 对你思念入骨的女人,跟你见面时会有这几种表现,藏都藏不住(对你思念入骨的女人)
- 纳兰性德绝美作,一场重逢,成就最后一首称得上惊艳的《如梦令》(纳兰性德绝美作)
- 如何快速赚钱(如何快速赚钱方法真实有效)
热门推荐
- 安装SQL Server 2016出错提示:需要安装oracle JRE7 更新 51(64位)或更高版本问题的解(安装SQL Server 2016出错提示:需要安装oracle JRE7 更新 5164位或更高版本问题的解)
- 如何用jquery进行表单验证(jQuery实现发送验证码控制按钮禁用功能)
- vueelementui左侧菜单(Vue Element前端应用开发之动态菜单和路由的关联处理)
- mysql触发器入门(MySQL中触发器和游标的介绍与使用)
- 申请云服务器后需要做哪些(云服务器网站承载量一般有多大?一个云服务器能够放几个网站?)
- laravel模型详解(laravel config文件配置全局变量的例子)
- Get和Post的区别
- rabbitmq延迟队列原理(Rabbitmq heartbea心跳检测机制原理解析)
- extjs card卡片式布局
- laravel命令行与可选项(Laravel6.0.4中将添加计划任务事件的方法步骤)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9