返回顶部
首页 > 资讯 > 数据库 >什么是MySQL的整体架构
  • 130
分享到

什么是MySQL的整体架构

2024-04-02 19:04:59 130人浏览 安东尼
摘要

下文主要给大家带来什么是Mysql的整体架构,希望这些内容能够带给大家实际用处,这也是我编辑什么是mysql的整体架构这篇文章的主要目的。好了,废话不多说,大家直接看下文吧。    &n

下文主要给大家带来什么是Mysql的整体架构,希望这些内容能够带给大家实际用处,这也是我编辑什么是mysql的整体架构这篇文章的主要目的。好了,废话不多说,大家直接看下文吧。                                                           

整体架构图

我们先看一下Mysql的架构图,对其先有一个整体的了解。MySQL主要分为四层架构,分别是网络连接层,服务层,存储引擎层,物理层。我们平常写的SQL语句,以及对SQL语句的优化都在服务层,他其实就是遵循一定的原则使得SQL语句能够按我们的预期效果执行。

什么是MySQL的整体架构

各部分介绍

网络连接层

主要负责连接管理,授权认证,安全等。每个客户端连接都对应着云服务器上的一个线程。云服务器上维护一个线程池,避免为每个连接创建和销毁线程。当客户端连接到MySQL云服务器时,云服务器对其进行认证。可以通过用户名与密码认证,也可以通过SSL证书进行认证。登录认证后,云服务器还会验证客户端是否有执行某个查询的操作权限。这一层并不是MySQL所特有的技术。

服务层

该层是MySQL的核心,包括查询缓存,解析器,解析树,预处理器,查询优化器。

什么是MySQL的整体架构

  • 查询缓存

在正式查询之前,云服务器会检查查询缓存,如果能找到对应的查询,则不必进行查询解析,优化,执行等过程,直接返回缓存中的结果集。

  • 解析器和预处理器

MySQL的解析器会根据查询语句,构造出一个解析树,主要用于根据语法规则来验证语句是否正确,比如SQL的关键字是否正确,关键字的顺序是否正确。

而预处理器主要是进一步校验,比如表名,字段名是否正确等。

  • 查询优化器

查询优化器将解析树转化为查询计划,一般情况下,一条查询可以有很多种执行方式,最终返回相同的结果,优化器就是找到这其中最优的执行计划

  • 执行计划

在完成解析和优化阶段后,MySQL根据相应的执行计划去调用存储引擎层提供的相应接口来获取结果。

存储引擎层

负责MySQL数据的存储和提取,是通过提供一系列的接口来屏蔽不同引擎之间的差异。

注意:存储引擎是针对表的,而不是针对库。也就是说同一个库里面的不同表可以拥有不同的存储引擎。

常见的存储引擎有两种,MyISAM和InnoDB,下面我们来看下他们的区别。

首先,我们先创建一个存储引擎为MyISAM的test1表。

create table test1( a INTEGER, b varchar(10) )ENGINE=MyISAM;

我们可以去MySQL的相关目录看一下他实际存储的内容,发现他对应着三个文件。

什么是MySQL的整体架构

其次,我们再创建一个存储引擎为InnoDB的test2表。

create table test2( a INTEGER, b varchar(10) )ENGINE=INNODB;

我们再去看一下他实际存储的内容,发现他对应这一个文件。

什么是MySQL的整体架构

那么问题就来了,他的数据文件和索引文件存放在哪里啦。这边先留个问题,下下篇"文件"再说。

物理层

将数据存放在硬盘上。

整体流程

我们发送一条SQL语句,其在MySQL中的整体流程究竟是什么样的?

  • 用户先通过Navicat等客户端与服务端建立连接,这边需要用户名和密码进行认证,也可以用SSL证书进行认证。

  • 登录成功后,MySQL会根据相应权限来判断该角色是否拥有一些表的权限等。

  • 如果拥有相关权限,当用户发送一条查询select语句时,MySQL先查询缓存,如果已经有这条语句的缓存,则直接返回,如果没有则执行下面的流程。如果是更新update,新增insert,删除delete则不查询缓存,直接执行下面的流程。

  • MySQL会将SQL语句解析为树,然后对其进行校验,比如关键字是否正确,关键字顺序是否正确,表名是否正确,字段是否正确等。如果认证没有成功,则直接返回错误。如果认证成功了,则直接下面流程。

  • MySQL对解析树进行查询优化,因为多个SQL可能表达的意思一样,但是消耗的时间可能差别很大。所以MySQL对针对表的存储引擎找到最优的语句执行,也就是生成相应的执行计划。

  • 使用上面生成的执行计划,来调用存储引擎层的接口。也就是我们平时使用的explain,其可以用来查看是否走索引,消耗的时间等信息。

  • 不同的存储引擎会到相应的物理存储位置,找到相应的数据,封装并返回结果。

  • 如果拿到了结果集,并且为select语句,MySQL会将结果放入到缓存中,避免下次再进行相同的操作而造成资源的消耗,同时返回给客户端结果,至此,一条SQL语句的执行过程结束啦。

  • 对于以上关于什么是MySQL的整体架构,大家是不是觉得非常有帮助。如果需要了解更多内容,请继续关注我们的数据库,相信你会喜欢上这些内容的。

您可能感兴趣的文档:

--结束END--

本文标题: 什么是MySQL的整体架构

本文链接: https://lsjlt.com/news/36206.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 什么是MySQL的整体架构
    下文主要给大家带来什么是MySQL的整体架构,希望这些内容能够带给大家实际用处,这也是我编辑什么是MySQL的整体架构这篇文章的主要目的。好了,废话不多说,大家直接看下文吧。    &n...
    99+
    2024-04-02
  • HBase整体架构是什么
    小编给大家分享一下HBase整体架构是什么,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!HBase 系统架构图组成部件说明   Client: ...
    99+
    2023-06-03
  • Web技术整体架构是什么
    本篇内容介绍了“Web技术整体架构是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! 开始的开始,就是...
    99+
    2024-04-02
  • 什么是MySQL体系架构
    本篇内容主要讲解“什么是MySQL体系架构”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“什么是MySQL体系架构”吧!写在前面很多小伙伴工作很长时间了,对于My...
    99+
    2024-04-02
  • MySQL 整体架构介绍
    MySQL 在整体架构上分为 Server 层和存储引擎层。其中 Server 层,包括连接器、查询缓存、分析器、优化器、执行器等,存储过程、触发器、视图和内置函数都在这层实现。数据引擎层负责数据的存储和提取,如 I...
    99+
    2022-05-23
    MySQL 整体架构 MySQL 整体架构介绍
  • Docker整体架构是怎样的
    这篇文章主要讲解了“Docker整体架构是怎样的”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Docker整体架构是怎样的”吧!用户是使用DockerClient与Docker Daemon...
    99+
    2023-06-04
  • MySQL整体架构与内存结构
    一  mysql 整体框架: MySQL是由SQL接口,解析器,优化器,缓存,存储引擎等组成的。   1. Connectors指的是不同语言中与SQL的交...
    99+
    2024-04-02
  • Mybatis整体架构及运行流程是什么
    本篇内容介绍了“Mybatis整体架构及运行流程是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!Mybatis是什么Mybatis是一个...
    99+
    2023-06-02
  • java Dubbo架构整体设计方法是什么
    这篇文章主要介绍“java Dubbo架构整体设计方法是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“java Dubbo架构整体设计方法是什么”文章能帮助大家解决问题。一、Dubbo调用关系说...
    99+
    2023-07-06
  • LevelDB的整体架构是怎样的
    本文小编为大家详细介绍“LevelDB的整体架构是怎样的”,内容详细,步骤清晰,细节处理妥当,希望这篇“LevelDB的整体架构是怎样的”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识...
    99+
    2024-04-02
  • go micro整体架构是怎样的
    这篇文章主要讲解了“go micro整体架构是怎样的”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“go micro整体架构是怎样的”吧!   微服务化项目...
    99+
    2024-04-02
  • MySQL架构是什么
    这篇文章主要介绍MySQL架构是什么,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!MySQL服务器架构、各种存储引擎间的主要区别及区别的重要性回顾MySQL历史背景、基准测试,通过简...
    99+
    2024-04-02
  • MySQL架构体系是怎样的
    本篇内容主要讲解“MySQL架构体系是怎样的”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“MySQL架构体系是怎样的”吧!一 : 数据库和数据库实例 在MySQL的学习研究中,存在两个...
    99+
    2023-06-05
  • MySQL实战优化之InnoDB整体架构
    一、InnoDB 更新数据得整体架构 每个组件的作用说明: 用一条更新数据来说明每个主键得作用: update student set name = "zhangsan" where id = 10 innodb得重要内存接...
    99+
    2015-12-01
    MySQL实战优化之InnoDB整体架构
  • TiDB整体架构介绍
    TiDB架构图如下 TiDB 集群主要分为三个组件: TiDB Server TiDB Server 负责接收 SQL 请求,处...
    99+
    2024-04-02
  • MySQL的体系架构
    文章目录 前言MySQL的Server层MySQL的存储引擎1)InnoDB 存储引擎2)MyISAM 存储引擎3)Memory 存储引擎 前言 在学习一种事务之前,我们需要先了解事物的基本组成结构,清楚了事物的基本组成结...
    99+
    2023-08-16
    mysql 架构 adb
  • MaxCompute访问控制整体架构是怎样的
    这篇文章主要介绍“MaxCompute访问控制整体架构是怎样的”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“MaxCompute访问控制整体架构是怎样的”文章能帮助大家解决问题。基本术语projec...
    99+
    2023-06-03
  • MySQL架构体系
    MySQL基本架构(一条SQL语句的执行过程) MySQL主要可以分为Server层和存储引擎层。 Server层包括连接器、查询缓存、分析器、优化器、执行器等,所有跨存储引擎的功能都在这一层实现。 存储引擎层负责数据的存储和提取。其架构...
    99+
    2018-05-07
    MySQL架构体系
  • TiDB简介与整体架构
    ---描述得很牛逼,有待验证 TiDB 简介 TiDB 是 PingCAP 公司受 Google Spanner / F1 论文启发而设计的开源分布式 NewSQL 数据库。 TiDB 具备...
    99+
    2024-04-02
  • mysql架构的原理是什么
    本篇内容主要讲解“mysql架构的原理是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“mysql架构的原理是什么”吧!Mysql 架构原理1、Mysql体系...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作