MySQL架构组件是什么

本篇文章给大家介绍一下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个可选值,分别为:

牛NIUCMS本地O2O系统 牛NIUCMS本地O2O系统

牛NIUCMS本地O2O系统是一个以php+mysql进行开发的o2o网站系统。NIUCMS是一款强大的网站管理系统。支持智慧城市、智慧小区、智慧乡村、本地生活门户、本地O2O平台的构建。请注意以下几点:1、这套源码必须要服务器支持伪静态,是支持.htaccess规则的伪静态,一般Apache服务器支持,别搞的下载回去以后说什么缺 少文件,其实源码并非缺少文件。2、这套源码请在php 5.4环境下

牛NIUCMS本地O2O系统 0 查看详情 牛NIUCMS本地O2O系统

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教程》

以上就是MySQL架构组件是什么的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/765291.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月26日 02:45:09
下一篇 2025年11月26日 02:48:15

相关推荐

  • 如何在Linux中查看服务的状态和日志?

    使用systemctl status查看服务状态,journalctl -u查看日志;通过list-units可列出运行或所有服务,is-enabled检查开机自启;journalctl支持按行数、时间、级别过滤日志,排查问题需结合状态与日志分析,并定期用–vacuum-time清理日志…

    2025年12月6日 运维
    000
  • Linux中如何安装MySQL_Linux安装MySQL数据库的步骤详解

    答案:在CentOS和Ubuntu上安装MySQL需先确认系统环境并更新,Ubuntu使用apt install mysql-server,CentOS需添加官方Yum源后安装,均需运行mysql_secure_installation进行安全配置,如需远程访问则修改bind-address为0.0…

    2025年12月6日 运维
    000
  • 如何在mysql中处理复制异常

    答案:MySQL复制异常需及时处理以保障数据一致性。首先通过SHOW SLAVE STATUS\G检查Slave_IO_Running、Slave_SQL_Running、Last_Error等字段判断复制状态;若出现主键冲突可设sql_slave_skip_counter跳过事务,表缺失则需手动建…

    2025年12月6日 数据库
    000
  • 如何在mysql中排查并发写入冲突

    首先通过系统表和日志定位锁冲突,再结合索引优化与事务设计降低争用。具体步骤包括:查询INNODB_TRX和INNODB_LOCK_WAITS确定阻塞关系;启用innodb_print_all_deadlocks分析死锁日志;确保写操作条件字段有索引以减少间隙锁;缩短事务长度并考虑使用READ COM…

    2025年12月6日 数据库
    000
  • 如何在mysql中创建单列索引

    创建单列索引可提升查询效率,使用CREATE INDEX或建表时添加INDEX关键字,如CREATE INDEX idx_email ON users(email),建议合理命名并避免频繁更新列。 在 MySQL 中创建单列索引是为了提升针对某一列的查询效率,尤其是在 WHERE、ORDER BY …

    2025年12月6日 数据库
    000
  • 抖音健康分12扣完会封号吗?多久恢复一次?深度解析平台规则

    在短视频内容爆发的当下,抖音健康分系统如同一道无形的“行为标尺”,实时评估着每位用户账号的合规程度。当创作者突然收到“您的健康分已被扣除”的提示时,最关心的问题莫过于:抖音健康分12分扣完会不会直接封号?被扣的分数多久才能恢复? 本文将深入解析抖音健康分的运行逻辑,并提供切实可行的账号管理建议。 一…

    2025年12月6日 自媒体
    000
  • 豆包Ai网页端官网链接_豆包Ai官方网页版地址

    豆包AI网页端官网链接是https://www.doubao.com/chat/,用户可通过该网址进行智能对话、内容生成、信息提炼和网页速读等操作。 ☞☞☞AI 智能聊天, 问答助手, AI 智能搜索, 免费无限量使用 DeepSeek R1 模型☜☜☜ 豆包Ai网页端官网链接在哪里?这是不少网友都…

    2025年12月6日 科技
    000
  • 快手官方网页版入口

    快手官方网页版入口 官网地址:www.kuaishou.com 快手作为国内领先的短视频与直播平台,致力于打造一个真实、多元的普通人生活记录空间。它不仅是一个内容展示窗口,更构建了一个互动频繁、情感连接紧密的社交生态圈。 平台主要特色 1、普惠理念与去中心化推荐机制 快手坚持“人人皆可被看见”的理念…

    2025年12月6日 软件教程
    000
  • JavaScript音频处理编程

    答案:JavaScript通过Web Audio API实现音频处理,核心是AudioContext。首先创建音频上下文,用于加载音频文件、合成波形、添加效果和可视化。使用fetch加载音频并解码,通过BufferSource播放;用OscillatorNode生成正弦波等音效;通过GainNode…

    2025年12月6日 web前端
    000
  • laravel如何实现JWT (JSON Web Tokens)认证_Laravel JWT认证实现方法

    首先安装 tymon/jwt-auth 包并注册服务提供者,接着生成配置文件与密钥,然后修改 auth 配置使用 jwt 驱动,用户模型实现 JWTSubject 接口,创建登录登出接口处理 Token 生成与销毁,通过 auth:api 中间件保护路由,并可刷新 Token 以延长有效期,完成 L…

    2025年12月6日 PHP框架
    000
  • 如何在安装mysql时选择数据存储路径

    安装 MySQL 时可自定义数据存储路径以优化磁盘空间与性能;2. Windows 用户可通过 MySQL Installer 在 Custom 模式下的 Advanced Options 中设置 Data Directory;3. Linux 与高级用户推荐通过编辑配置文件 my.cnf 或 my…

    2025年12月6日 数据库
    000
  • Grok在线官网首页_Grok官方网站直达地址

    Grok在线官网首页是https://grok.com,国内用户因网络限制无法直接访问,可通过镜像网站如https://chat.lanjing.pro或https://xsimplechat.com体验。 ☞☞☞AI 智能聊天, 问答助手, AI 智能搜索, 免费无限量使用 DeepSeek R1…

    2025年12月6日 科技
    000
  • laravel Jetstream和Breeze的对比和选择_Laravel Jetstream与Breeze对比指南

    Laravel Jetstream功能全面,适合需团队管理及API支持的中大型项目;Breeze轻量简洁,提供基础认证,便于自由扩展和深度定制,适合小型项目或学习使用。 Laravel Jetstream 和 Laravel Breeze 都是官方提供的应用脚手架,用于快速搭建包含用户认证功能的项目…

    2025年12月6日 PHP框架
    000
  • 如何在mysql中开发在线考试系统数据库

    答案是设计在线考试系统数据库需明确用户、科目、试题、试卷、考试记录等核心模块,通过MySQL建立users、subjects、questions、options、exams、exam_questions、exam_attempts和user_answers等表,利用外键约束保证数据完整性,采用JSO…

    2025年12月6日 数据库
    000
  • 豆包Ai在线网页版官网_豆包Ai官方网页访问平台

    豆包AI在线网页版官网是https://www.doubao.com/chat/,用户可通过该平台使用智能对话、多模式服务切换、历史记录管理及跨设备同步等功能。 ☞☞☞AI 智能聊天, 问答助手, AI 智能搜索, 免费无限量使用 DeepSeek R1 模型☜☜☜ 豆包Ai在线网页版官网在哪里?这…

    2025年12月6日 科技
    000
  • 如何在Linux中使用rsync备份文件系统?

    rsync通过仅传输文件变化部分实现高效备份,支持本地与远程同步;2. 常用选项包括-a(归档)、-v(详细输出)、-z(压缩)、–delete(删除多余文件)等;3. 路径末尾斜杠决定是否同步目录内容;4. 远程备份可通过SSH推送或拉取,需配置密钥免密登录;5. 结合脚本与cron可…

    2025年12月6日 运维
    000
  • laravel Eloquent如何处理JSON字段的查询_Laravel Eloquent JSON字段查询处理方法

    Laravel Eloquent支持JSON字段查询与更新,使用->操作符访问键值,如profile->age;支持嵌套查询如profile->address->province;可用whereJsonContains查询数组内容;结合$casts属性自动转换JSON字段为数…

    2025年12月6日 PHP框架
    000
  • mysql中如何查看启动错误信息

    首先通过错误日志定位MySQL启动问题,1. 查找日志路径:检查配置文件my.cnf/my.ini中的log_error项,或执行SHOW VARIABLES LIKE ‘log_error’;,或查看默认路径如/var/log/mysqld.log;2. 使用tail -f…

    2025年12月6日 数据库
    000
  • AIGC检测官网入口 知网免费查重链接直达

    知网AIGC检测官方入口为https://cx.cnki.net,基于大模型算法提供中英文论文AI生成内容识别服务。该平台结合知识增强与语义分析技术,生成可视化报告,适用于毕业、职称等学术文本自查。检测服务需注册账号并付费使用,官方不提供永久免费查重。第三方“免费查重”存在数据泄露或结果不准风险,建…

    2025年12月6日 科技
    000
  • mac怎么更改电脑的网络名称_Mac更改电脑网络名称方法

    可通过系统设置修改Mac网络名称:进入“系统设置-通用-关于”,更改“名称”字段即可;2. 建议同步在“共享”中更新“电脑名称”以确保一致性;3. 高级用户可用终端命令分别设置ComputerName、HostName和LocalHostName实现精确控制,三项建议统一。 如果您希望在局域网中让您…

    2025年12月6日 系统教程
    000

发表回复

登录后才能评论
关注微信