面试题15: Mysql 数据存储原理

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 面试题15: Mysql 数据存储原理

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB公司开发,目前属于Oracle公司。MySQL是一种关系型数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放入一个大仓库内,这使得速度增快,灵活性增强。


一:MySQL主要特性


MySQL的存储原理主要涉及到存储引擎、索引、事务处理、锁定机制等方面。


1. 存储引擎


MySQL的最大特色之一是其插件式的存储引擎架构,这种架构可以让用户选择最适合自己需求的存储引擎。常见的MySQL存储引擎有MyISAM、InnoDB、Memory等。


- MyISAM:MyISAM是MySQL的默认存储引擎(直到MySQL 5.5版本)。MyISAM非常适合于:1) 需要高速读取的系统 2) 只做插入操作,而不需要修改或删除操作的系统。


- InnoDB:InnoDB是一个可以提供有提交、回滚和崩溃恢复能力的事务安全(ACID兼容)的存储引擎。但是在InnoDB中读取操作(不是改变数据的查询)也会产生副本。因此,InnoDB适合处理大量的数据。


- Memory:所有的数据都在内存中,数据的处理速度快,但是安全性不高。如果数据库重启,所有的数据都会消失。


2.索引


为了提高查询效率,MySQL提供了索引机制。MySQL提供了主键索引、唯一索引、全文索引等多种索引,并且支持多列索引。索引是在存储引擎层实现的,所以不同的存储引擎可能会有不同的索引类型和实现。


3.事务处理


事务是一系列的数据操作语句,事务是一个不可分割的工作单位,只有所有的操作都成功,事务才算成功。如果一个操作失败,那么这个事务就会回滚到事务开始前的状态。


4.锁定机制


MySQL中的锁定机制可以确保在并发环境下数据的一致性。锁定机制包括共享锁(读锁)和排他锁(写锁),InnoDB存储引擎还支持行级锁和表级锁。


二:MySQL的存储原理


Mysql的数据库存储原理主要有以下几点:


1. 数据存储在磁盘上。Mysql数据库系统将数据存储在磁盘文件中,这些文件又分为以下几类:


- 数据库目录文件(.frm文件):存储表结构信息。


- 数据文件(.MYD文件):存储表中的实际数据。


- 索引文件(.MYI文件):存储表的索引。


2. 数据以页为单位存储。Mysql数据库以页(Page)为单位将数据存储在数据文件中,默认的页大小是16KB。


3. 数据在磁盘上以表空间的形式组织。表空间是由一个或多个数据文件组成的逻辑存储单元,每个表空间存储一系列的表。


4. 每个存储引擎有自己的存储机制。不同的存储引擎有不同的数据存储和索引实现机制,如InnoDB使用聚集索引、MyISAM使用非聚集索引。


5. 使用缓冲池缓存经常访问的数据。缓冲池缓存磁盘上的数据页,使之留在内存中,提高访问速度。


6. 使用渐进式写入技术。Mysql不会立即将缓存中的脏页刷新到磁盘,而是按需周期性地刷新。


7. 使用检查点技术保证数据的完整性。检查点机制会在主数据文件更新时,同时更新日志文件或重做日志,以便在系统故障时使用日志恢复数据。

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
11天前
|
JavaScript 前端开发
【Vue面试题二十五】、你了解axios的原理吗?有看过它的源码吗?
这篇文章主要讨论了axios的使用、原理以及源码分析。 文章中首先回顾了axios的基本用法,包括发送请求、请求拦截器和响应拦截器的使用,以及如何取消请求。接着,作者实现了一个简易版的axios,包括构造函数、请求方法、拦截器的实现等。最后,文章对axios的源码进行了分析,包括目录结构、核心文件axios.js的内容,以及axios实例化过程中的配置合并、拦截器的使用等。
【Vue面试题二十五】、你了解axios的原理吗?有看过它的源码吗?
|
10天前
|
安全 Java 容器
【Java集合类面试二十七】、谈谈CopyOnWriteArrayList的原理
CopyOnWriteArrayList是一种线程安全的ArrayList,通过在写操作时复制新数组来保证线程安全,适用于读多写少的场景,但可能因内存占用和无法保证实时性而有性能问题。
|
11天前
|
JavaScript 前端开发
【Vue面试题二十七】、你了解axios的原理吗?有看过它的源码吗?
文章讨论了Vue项目目录结构的设计原则和实践,强调了项目结构清晰的重要性,提出了包括语义一致性、单一入口/出口、就近原则、公共文件的绝对路径引用等原则,并展示了单页面和多页面Vue项目的目录结构示例。
|
11天前
|
存储 缓存 JavaScript
【Vue面试题十八】、你知道vue中key的原理吗?说说你对它的理解
这篇文章详细介绍了Vue中的`keep-alive`组件,解释了其作用是缓存不活动的组件实例以避免重复渲染DOM,并阐述了`keep-alive`的使用场景、props属性配置、以及如何通过源码理解其缓存机制和原理。
【Vue面试题十八】、你知道vue中key的原理吗?说说你对它的理解
|
11天前
|
JavaScript 算法
【Vue面试题十七】、你知道vue中key的原理吗?说说你对它的理解
这篇文章深入探讨了Vue中`key`的原理及其作用,解释了`key`是为每个虚拟DOM节点提供的唯一标识符,作为`diff`算法的优化策略,有助于更快速准确地识别和重用DOM元素。文章通过实际代码示例展示了使用`key`与否在列表渲染时对DOM操作的影响,分析了`key`在不同场景下的性能表现,并提供了源码层面的分析,解释了Vue如何通过`key`来识别和更新虚拟DOM节点。
【Vue面试题十七】、你知道vue中key的原理吗?说说你对它的理解
|
7天前
|
SQL 关系型数据库 MySQL
说一下MySQL主从复制的原理?
【8月更文挑战第24天】说一下MySQL主从复制的原理?
29 0
|
10天前
|
Java
【Java集合类面试二十一】、请介绍TreeMap的底层原理
TreeMap基于红黑树实现,能够根据键的自然顺序或提供的Comparator排序,其基本操作的时间复杂度为O(log N)。
|
10天前
|
Java
【Java集合类面试二十】、请介绍LinkedHashMap的底层原理
LinkedHashMap的底层原理是在HashMap的基础上,通过维护一条双向链表来保持键值对的插入和遍历顺序,同时继承HashMap的多数方法并重写部分方法以维护链表。
|
12天前
|
SQL 关系型数据库 MySQL
面试准备-MySQL
面试准备-MySQL
|
11天前
|
SQL 关系型数据库 MySQL
Mysql原理与调优-事务与MVCC
【8月更文挑战第19天】
下一篇
云函数