0

0

MySQL架构组件是什么

醉折花枝作酒筹

醉折花枝作酒筹

发布时间:2021-05-17 09:41:59

|

2017人浏览过

|

来源于CSDN

转载

本篇文章给大家介绍一下mysql架构组件。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。

MySQL架构组件是什么

总体架构

在这里插入图片描述

一. 连接器

  连接器主要负责跟客户端建立连接、权限验证和管理连接,可以使用命令show processlist查看连接信息。当一个用户连接创建成功之后,权限信息就已经读入内存,之后再修改该用户的权限,如果不刷新的话,则无法生效。

  对于一个连接,如果长时间没有收到指令(处于空闲状态),那么达到一定的时间之后,连接器会断开这个链接。这个时间由参数wait_timeout控制,默认为8小时。

  连接器中的连接分为长连接和短连接:

  • 长连接:连接成功后,客户端请求使用同一个连接

  • 短连接:每次执行完请求后会断开连接,再有请求会重新建立连接

  由于在平时我们一般为了避免频繁反复创建连接的开销,都是使用的长连接,也就是长期维持一个连接不断开。但是要注意,一个连接管理了其在使用过程中占用的一些内存,会在连接断开的时候随连接一起释放。如果连接不断开,长期不处理一直堆积,则可能导致内存占用过大,被系统强杀。一般有两个解决方案:

  • 定期断开长连接,每隔一段时间或执行一个占用大量内存的查询之后断开连接,从而释放内存,当需要查询的时候再重新创建连接

  • 5.7之后的版本可以使用mysql_reset_connection来重新初始化连接资源,不需要重新连接和权限验证,而将连接恢复到新建时的状态。同时也会有一些其它影响,比如释放表锁、清除临时表、重置会话中设置的变量等等

二、 查询缓存

注:查询缓存8.0 版本后被废除

  连接创建成功之后就可以执行SQL语句了,不过如果开启了查询缓存,那么在真正分析SQL之前会先从缓存中查询,如果缓存命中则直接返回。查询缓存就是一个Key-Value结构,Key是SQL语句,Value是对应的查询结果。如果缓存未命中,就会继续后面的查询操作。查询完成之后,会把结果存入查询缓存中。

  为什么查询缓存会被删除呢?因为查询缓存通常弊大于利。如果对一个表进行更新,那么这个表对应的查询缓存都会被清空,对于经常更新的表,查询缓存的失效会非常频繁,基本就不起作用,而且还有更新缓存的开销。对于那种基本会保持不变的数据表,倒是可以选择使用查询缓存,比如系统配置表等,这种表的缓存命中率会高些,可能能做到利大于弊,不过对于这种配置,我们还可以使用外部缓存。

  通过参数query_cache_type可以配置查询缓存,该参数有3个可选值,分别为:

手机在线人工冲值
手机在线人工冲值

说明:我不知道这个系统还能用到什么地方!他的运作方式是这样的,客户在其他地方比如掏宝购买了 你得卡,然后在你的网站进行冲值,你得有人登陆并看着后台,如果有人冲值,就会刷出记录,手工冲值完毕后,你得点击 [冲值完毕],客户的页面 就会返回 冲值信息!安装:上传所有文件,倒入(sql.txt)mysql数据库,使用myphpadminphplib 777phplib/sys.php 777phplib

下载
  • 0:关闭查询缓存

  • 1:开启查询缓存

  • 2:当SQL中有SQL_CACHE关键词时使用查询缓存,比如select SQL_CACHE * from t where xxx;

三、分析器

  如果查询缓存没有命中,那么SQL就需要真正得到执行,在执行之前需要对SQL进行解析,这个解析主要分为词法分析和语法分析两个步骤。

  • 词法分析:从SQL中提取关键词,比如select 、from、表名、字段名等等

  • 语法分析:根据词法分析的结果和MySQL定义的一些语法规则检查SQL语法是否合法,最终会生成一颗抽象语法树(AST)

四、 优化器

  优化器以分析器生成的AST为输入,对SQL进行优化,生成优化器认为的最优执行方案,交给执行器执行。优化过程包括SQL的逻辑转换和代价计算。

  逻辑转化就类似于Java的静态编译期优化,会对SQL进行一些"简化",保证SQL转换前后执行结果一致。比如,where 1=1 and a.id = 2,可以相当于where a.id = 2。

  代价计算的主要目的是选择SQL执行的方式,包括是否使用索引、使用哪个索引、多表连接使用什么顺序等。代价分为服务层代价和引擎层代价,服务层代价主要是CPU相关,引擎层代价则主要是磁盘I/O相关。MySQL 5.7 引入了两个系统表mysql.server_cost和mysql.engine_cost来配置这两种代价,表中配置的就是各种操作对应的代价,比如临时表创建、排序、页读取等等。

  优化器会根据生成的查询计划和上述两种代价配置来计算一个查询计划的最终代价,在多个查询计划中选择代价最小的那一个交给执行器执行。但是要注意,代价最小,有时候并不一定代表执行时间就最短。

五、 执行器

  执行器会根据优化器选择的查询计划去执行SQL,执行之前还会校验请求用户是否拥有对应的查询权限,最终调用MySQL引擎层提供的接口,执行SQL语句并且返回结果。如果开启了查询缓存,结果还会存储在查询缓存中。

相关推荐:《mysql教程

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

1133

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

340

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

381

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

2152

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

380

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

1663

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

585

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

440

2024.04.29

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

3

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 2.5万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 846人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号