MySQL架构设计

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS PostgreSQL,高可用系列 2核4GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 系统只要能从数据库连接池获取到一个数据库连接,就能执行CRUD。可通过数据库连接将待执行SQL发给MySQL。

系统只要能从数据库连接池获取到一个数据库连接,就能执行CRUD。可通过数据库连接将待执行SQL发给MySQL。


大部分 crud boy只知道:


执行insert语句后,在表里会多条数据

执行update后,会更改表数据

执行delete后,会删除表里数据

执行select后,会查询表里数据出来

要是SQL性能丢人,建几个索引解决

这应该是目前行业内很多工程师对数据库的一个认知,完全当他是个黑盒来建表及执行SQL。


网络连接必须有线程处理


假设数据库服务器的连接池中的某个连接,接收到一条SQL网络请求,请思考:


谁负责从这个连接中去监听网络请求?

谁负责从网络连接里把请求数据读取出来?

网络连接得有一个线程来监听请求及读取请求数据,比如从网络连接中读取和解析出来一条业务系统发的SQL语句:

7.png



SQL接口


负责处理接收到的SQL语句。


MySQL的工作线程从一个网络连接中读出一个SQL语句后,会如何执行该SQL呢?


MySQL提供了SQL接口(SQL Interface),一套执行SQL语句的接口,专门执行业务系统发送的那些CRUD语句


因此MySQL的工作线程接收到SQL语句之后,就会转交给SQL接口去执行:

6.png



查询解析器


那SQL接口怎么执行SQL语句的?这玩意能懂这些SQL语句?


假设有如下SQL:


select id,name,age from users where id=1


这就需要查询解析器(Parser),负责解析SQL语句,比如对那个SQL拆解成:


要从“users”表里查询数据

查询“id”字段的值等于1的那行数据

对查出来的那行数据要提取里面的“id,name,age”三字段

SQL解析也就是按SQL语法来解析SQL语句意欲何为:

5.png



查询优化器


通过解析器知道SQL要干啥了,然后就得找查询优化器(Optimizer)选择一个最优查询路径。


啥叫最优查询路径呢?


之前的那个SQL:从“users”表里查询数据,查“id”字段的值等于1的那行数据,对查出来的那行数据要提取里面的“id,name,age”三个字段。


要完成此事有如下查询路径:


直接定位到users表中的id字段等于1的那行数据,查出来那行数据的id、name、age三个字段值

先把users表中的每行数据的“id,name,age”三个字段的值都查出来,然后从这批数据里过滤出来“id”字段等于1的那行数据的“id,name,age”三个字段

可见,完成该SQL,两条路径都能实现,那到底选哪个呢?显然第一种性能更好。


所以查询优化器大概就是这个意义,他会针对你的SQL生成查询路径树,选择最优查询路径。

4.png



调用存储引擎接口,真正执行SQL语句。


把查询优化器选择的最优查询路径,即到底应该按照一个什么样的顺序和步骤去执行这个SQL语句的计划,把该计划交给底层的存储引擎去真正执行。


假设我们的数据有的存在内存,有的存在磁盘文件,那到底怎么知道


哪些数据在内存?

哪些在磁盘?

执行时:


是更新内存数据?

还是更新磁盘数据?

若更新磁盘数据:


先查询哪个磁盘文件

再更新哪个磁盘文件?

这就需要存储引擎,就是个执行SQL语句的,会按步骤查询内存缓存数据,更新磁盘数 据,查询磁盘数据等,执行此类的一系列的操作:


3.png


MySQL架构设计中,SQL接口、SQL解析器、查询优化器都是通用的,属于一套组件。但支持各种存储引擎,如InnoDB、MyISAM、Memory等,可以选择具体使用哪种存储引擎来负责执行SQL。


执行器


根据执行计划调用存储引擎的接口。


存储引擎可帮助我们去访问内存及磁盘上的数据,那谁来调存储引擎的接口?


那就是执行器,会根据优化器选择的执行方案,按照一定的顺序和步骤调用存储引擎的接口,执行SQL逻辑。


比如执行器可能先调用存储引擎的一个接口,获取“users”表中的第一行数据,然后判断一下这个数据的“id”字段的值是否等于我们期望的一个值,如果不是的话,那就继续调用存储引擎的接口,去获取“users”表的下一行数据。


也就这套操作,执行器会根据优化器生成的执行计划,不停调用存储引擎的接口们,去完成SQL语句的执行计划,即不停的更新或提取一些数据:

2.png


相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
目录
相关文章
|
6月前
|
负载均衡 算法 关系型数据库
大数据大厂之MySQL数据库课程设计:揭秘MySQL集群架构负载均衡核心算法:从理论到Java代码实战,让你的数据库性能飙升!
本文聚焦 MySQL 集群架构中的负载均衡算法,阐述其重要性。详细介绍轮询、加权轮询、最少连接、加权最少连接、随机、源地址哈希等常用算法,分析各自优缺点及适用场景。并提供 Java 语言代码实现示例,助力直观理解。文章结构清晰,语言通俗易懂,对理解和应用负载均衡算法具有实用价值和参考价值。
大数据大厂之MySQL数据库课程设计:揭秘MySQL集群架构负载均衡核心算法:从理论到Java代码实战,让你的数据库性能飙升!
|
5月前
|
关系型数据库 MySQL 分布式数据库
Super MySQL|揭秘PolarDB全异步执行架构,高并发场景性能利器
阿里云瑶池旗下的云原生数据库PolarDB MySQL版设计了基于协程的全异步执行架构,实现鉴权、事务提交、锁等待等核心逻辑的异步化执行,这是业界首个真正意义上实现全异步执行架构的MySQL数据库产品,显著提升了PolarDB MySQL的高并发处理能力,其中通用写入性能提升超过70%,长尾延迟降低60%以上。
|
存储 SQL 关系型数据库
Mysql高可用架构方案
本文阐述了Mysql高可用架构方案,介绍了 主从模式,MHA模式,MMM模式,MGR模式 方案的实现方式,没有哪个方案是完美的,开发人员在选择何种方案应用到项目中也没有标准答案,合适的才是最好的。
892 3
Mysql高可用架构方案
|
11月前
|
存储 SQL 关系型数据库
MySQL进阶突击系列(03) MySQL架构原理solo九魂17环连问 | 给大厂面试官的一封信
本文介绍了MySQL架构原理、存储引擎和索引的相关知识点,涵盖查询和更新SQL的执行过程、MySQL各组件的作用、存储引擎的类型及特性、索引的建立和使用原则,以及二叉树、平衡二叉树和B树的区别。通过这些内容,帮助读者深入了解MySQL的工作机制,提高数据库管理和优化能力。
|
7月前
|
负载均衡 算法 关系型数据库
大数据新视界--大数据大厂之MySQL数据库课程设计:MySQL集群架构负载均衡故障排除与解决方案
本文深入探讨 MySQL 集群架构负载均衡的常见故障及排除方法。涵盖请求分配不均、节点无法响应、负载均衡器故障等现象,介绍多种负载均衡算法及故障排除步骤,包括检查负载均衡器状态、调整算法、诊断修复节点故障等。还阐述了预防措施与确保系统稳定性的方法,如定期监控维护、备份恢复策略、团队协作与知识管理等。为确保 MySQL 数据库系统高可用性提供全面指导。
|
监控 关系型数据库 MySQL
深入了解MySQL主从复制:构建高效稳定的数据同步架构
深入了解MySQL主从复制:构建高效稳定的数据同步架构
350 1
|
NoSQL 关系型数据库 MySQL
微服务架构下的数据库选择:MySQL、PostgreSQL 还是 NoSQL?
在微服务架构中,数据库的选择至关重要。不同类型的数据库适用于不同的需求和场景。在本文章中,我们将深入探讨传统的关系型数据库(如 MySQL 和 PostgreSQL)与现代 NoSQL 数据库的优劣势,并分析在微服务架构下的最佳实践。
|
9月前
|
SQL 存储 缓存
MySQL的架构与SQL语句执行过程
MySQL架构分为Server层和存储引擎层,具有高度灵活性和可扩展性。Server层包括连接器、查询缓存(MySQL 8.0已移除)、分析器、优化器和执行器,负责处理SQL语句;存储引擎层负责数据的存储和读取,常见引擎有InnoDB、MyISAM和Memory。SQL执行过程涉及连接、解析、优化、执行和结果返回等步骤,本文详细讲解了一条SQL语句的完整执行过程。
306 3
|
SQL 存储 缓存
【赵渝强老师】MySQL的体系架构
本文介绍了MySQL的体系架构,包括Server层的7个主要组件(Connectors、Connection Pool、Management Service & Utilities、SQL Interface、Parser、Optimizer、Query Caches & Buffers)及其作用,以及存储引擎层的支持情况,重点介绍了InnoDB存储引擎。文中还提供了相关图片和视频讲解。
421 2
【赵渝强老师】MySQL的体系架构
|
11月前
|
SQL 存储 关系型数据库
MySQL进阶突击系列(01)一条简单SQL搞懂MySQL架构原理 | 含实用命令参数集
本文从MySQL的架构原理出发,详细介绍其SQL查询的全过程,涵盖客户端发起SQL查询、服务端SQL接口、解析器、优化器、存储引擎及日志数据等内容。同时提供了MySQL常用的管理命令参数集,帮助读者深入了解MySQL的技术细节和优化方法。

推荐镜像

更多