mysql 体系结构和存储引擎介绍


Posted in MySQL onMay 06, 2022

1 前言

mysql 是一个单进程多线程架构的可移植的数据库,mysql 数据库实例在系统上的表现就是一个进程,可以在所有的平台上运行。

mysql 的整体架构图如下图所示: 

mysql 体系结构和存储引擎介绍

2 mysql 配置文件加载顺序

mysql 启动会读取配置文件,根据配置文件的参数启动数据库实例,数据库的配置文件为my.cnf,按照/etc/my.cnf -> /etc/mysql/my.cnf -> /usr/local/mysql/etc/my.cnf -> ~/my.cnf配置文件进行顺序加载,如果有相同的配置,则以最后一个加载的为准,这个和 springboot 的配置文件加载启动顺序是类似的。

3 mysql 引擎介绍

存储引擎是基于表的,而不是数据库。关于数据库引擎的语句为:

# 修改数据库引擎的语句
alter table table_name engine=MyISAM;
# 查询数据库可以支持的数据库引擎
show engines

查看数据库支持的引擎结果如下图所示: 

mysql 体系结构和存储引擎介绍

 mysql 存储引擎有 InnoDB,MyISAM,NDB 引擎,Memory 引擎, Archive 引擎,Federated 引擎,Maria 引擎。

3.1 InnoDB 引擎

InnoDB 存储引擎支持事务,其涉及目标主要是面向在线事务处理(OTLP),其特点是支持行锁和外键,并支持非锁定读(即读取数据默认不会加锁),从 mysql 5.5.8 版本开始,InnoDB 存储引擎就是mysql 的默认存储引擎。

InnoDB 存储引擎将数据存放在一个逻辑表空间中。InnoDB 通过使用多版本并发控制(MVCC)来获得高并发性的性能,并实现了SQL标准的4中隔离级别,默认使用 repeatable 级别。同时 innodb 引擎使用 next-locking 的测了来避免幻读现象的产生。除此之外,Innodb 引擎还提供了插入缓存,二次写,自适应哈希索引,预读等高性能和高可用的功能。

Innodb 存储引擎采用了聚集的方式,因此每张表都是按照主键的顺序进行存放的。如果没有显示的指定表的主键,那么存储引擎会为每行生成一个6字节的 rowid ,并以此作为主键使用。

3.2 MyISAM 引擎

MyISAM 存储引擎不支持事务、支持表锁不支持行锁,支持全文索引,主要面向一些 OLAP 数据库应用。数据库系统和文件系统很大的一个不同点在于对事务的支持,然而MyISAM存储引擎不支持事务,InnoDB 引擎支持,其引擎的缓冲池之缓存索引文件,而不缓存数据文件,这个和大多数的数据库不同。

MyISAM 存储引擎表是由 MYD 和 MYI 组成的一个系统,前者用于存放数据文件,后者是存放索引文件。

3.3 NDB 引擎

NDB 引擎是一个集群存储引擎,其结构是 share nothing 的集群架构,因此能够提供高可用性。NDB 的特点是数据全部存放在内存中,因此根据主键查询的效率速度极快,并且通过添加存储节点来提高数据库的性能。该存储引擎的连接操作是在数据库底层完成的,而不是在存储引擎层完成的,如果是复杂的数据库连接需要巨大的网络开销,查询速度比较慢。

3.4 Archive 引擎

Archive 引擎只支持 insert 和 select 操作,从 mysql5.1 之后开始支持索引,可以使用 zlib 算法进行数据行的压缩,压缩比可以达到 1:10,改引擎特别适合做数据的归档操作,比如说日志信息。该引擎使用行锁来实现高并发的插入操作,但是其本身不是事务安全的,其设计目的主要是提供高速插入和压缩功能。

3.5 Federated 引擎

Federated 存储引擎并不存放数据,它只是指向远程 mysql 数据库服务器上的表,改引擎只支持mysql 数据库表,不支持异构数据表。

3.6 Maria 引擎

Maria 引擎是新开发的数据库引擎,其设计目的是用来取代 MyISAM 引擎,从而成为 MySQL 的默认存储引擎。该引擎的特点是:支持缓存数据和索引文件,应用了行锁设计,提供了 MVCC 功能,支持事务和非事务安全的选项,以及更好的 BLOB 字符类型的处理性能。

3.7 其它引擎

除了以上提到的数据库引擎外,还有CSVMerge等数据库引擎, 感兴趣的可以继续关注学习。

4 总结

到此这篇关于mysql 体系结构和存储引擎介绍的文章就介绍到这了,更多相关mysql 存储引擎内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

MySQL 相关文章推荐
MySQL kill不掉线程的原因
May 07 MySQL
MySQL 分组查询的优化方法
May 12 MySQL
一看就懂的MySQL的聚簇索引及聚簇索引是如何长高的
May 25 MySQL
MySQL注入基础练习
May 30 MySQL
MySQL5.7并行复制原理及实现
Jun 03 MySQL
MySQL 不等于的三种使用及区别
Jun 03 MySQL
Mysql中存储引擎的区别及比较
Jun 04 MySQL
为什么代码规范要求SQL语句不要过多的join
Jun 23 MySQL
一文带你探究MySQL中的NULL
Nov 11 MySQL
Mysql中有关Datetime和Timestamp的使用总结
Dec 06 MySQL
MySql中的json_extract函数处理json字段详情
Jun 05 MySQL
MySQL中正则表达式(REGEXP)使用详解
Jul 07 MySQL
MySQL数据库 安全管理
May 06 #MySQL
Mysql 文件配置解析介绍
May 06 #MySQL
MySQL数据库中的锁、解锁以及删除事务
May 06 #MySQL
mysql性能优化以及配置连接参数设置
May 06 #MySQL
Mysql InnoDB 的内存逻辑架构
详细介绍MySQL中limit和offset的用法
May 06 #MySQL
MySQL数据库Innodb 引擎实现mvcc锁
May 06 #MySQL
You might like
Phpbean路由转发的php代码
2008/01/10 PHP
php实现批量下载百度云盘文件例子分享
2014/04/10 PHP
分享PHP计算两个日期相差天数的代码
2015/12/23 PHP
Yii rules常用规则示例
2016/03/15 PHP
PHP随机获取未被微信屏蔽的域名(微信域名检测)
2017/03/19 PHP
JavaScript CSS修改学习第六章 拖拽
2010/02/19 Javascript
js操作textarea方法集合封装(兼容IE,firefox)
2011/02/22 Javascript
js/ajax跨越访问-jsonp的原理和实例(javascript和jquery实现代码)
2012/12/27 Javascript
js隐藏与显示回到顶部按钮及window.onscroll事件应用
2013/01/25 Javascript
js复制到剪切板的实例方法
2013/06/28 Javascript
javascript中直接写php代码的方法
2013/07/31 Javascript
控制input输入框中提示信息的显示和隐藏的方法
2014/02/12 Javascript
什么是MEAN?JavaScript编程中的MEAN是什么意思?
2014/12/18 Javascript
jQuery实现自动切换播放的经典滑动门效果
2015/09/12 Javascript
JavaScript jQuery 中定义数组与操作及jquery数组操作
2015/12/18 Javascript
js实现正则匹配中文标点符号的方法
2015/12/23 Javascript
js格式化输入框内金额、银行卡号
2016/02/01 Javascript
JavaScript数据结构链表知识详解
2016/11/21 Javascript
jQuery实现级联下拉框实战(5)
2017/02/08 Javascript
jquery Easyui Datagrid实现批量操作(编辑,删除,添加)
2017/02/20 Javascript
使用Vue.observable()进行状态管理的实例代码详解
2019/05/26 Javascript
微信小程序录音实现功能并上传(使用node解析接收)
2020/02/26 Javascript
[04:38]完美世界携手游戏风云打造 卡尔工作室饰品系统篇
2013/04/25 DOTA
python实现apahce网站日志分析示例
2014/04/02 Python
python中类的一些方法分析
2014/09/25 Python
Pandas 对Dataframe结构排序的实现方法
2018/04/10 Python
解决使用export_graphviz可视化树报错的问题
2019/08/09 Python
关于Numpy数据类型对象(dtype)使用详解
2019/11/27 Python
基于FME使用Python过程图解
2020/05/13 Python
Python正则表达式高级使用方法汇总
2020/06/18 Python
python实现猜拳游戏项目
2020/11/30 Python
Ajxa常见问题都有哪些
2014/03/26 面试题
教师学习十八届五中全会精神心得体会
2016/01/05 职场文书
使用Golang的channel交叉打印两个数组的操作
2021/04/29 Golang
SQL优化老出错,那是你没弄明白MySQL解释计划用法
2021/11/27 MySQL
十大最强电系宝可梦,阿尔宙斯电系之一,第七被称为雷神
2022/03/18 日漫