mysql工作流程

mysql中有一个查询会话请求,那么大概流程如下:

        1.mysql客户端对mysql server的监听端口发起请求。

        2.在连接者组件层创建连接、分配线程,并验证用户名、密码和库表权限

        3.如果打开了query_cache,则检查,有结果直接返回给客户端。没有继续向下执行。

        4.sql接口组件接受sql语句,将sql语句分解成数据结构,并将这个结构传递到后续步骤中(将sql语句解析成mysql认识的语法)

        5.查看优化器组件并生成查询路径树,并选举一条最优的查询路径

        6.调用存储引擎接口,打开表,执行查询,检查存储引擎缓存中是否有对应的缓存记录,如果没有就继续往下执行。

        7.到磁盘物理文件中寻找数据

        8.当查询到所需要的数据之后,先写入存储引擎中,如果打开了query_cache,也会同时写进去

        9. 返回数据给客户端

        10.关闭表

        11.关闭线程

        12.关闭连接

.

mysql的各组件详解:

• Connectors(连接者):指的是不同语言中与SQL的交互,从图3-1 中可以看到目前流行的语言都支持MySQL客户端连接。

• Connection Pool(连接池):管理缓冲用户连接、线程处理等需要 缓存的需求。在这里也会进行用户账号、密码和库表权限验证。

• SQL Interface(SQL接口):接收用户执行的SQL语句,并返回查 询的结果。

• Parser(查询解析器):SQL语句被传递到解析器时会进行验证和 解析(解析成MySQL认识的语法,查询什么表、什么字段)。解析器是由 Lex和YACC实现的,是一个很长的脚本。其主要功能是将SQL语句分解成 数据结构,并将这个结构传递到后续步骤中,后续SQL语句的传递和处理 就是基于这个结构的。如果在分解构成中遇到错误,则说明该SQL语句可 能有语法错误或者不合理。

• Optimizer(查询优化器):在查询之前,SQL语句会使用查询优化 器对查询进行优化(生成查询路径树,并选举一条最优的查询路径)。它 使用“选取—投影—连接”策略进行查询。

• Caches& Buffers(缓存&缓冲):主要包含QC以及表缓存、权限缓 存等。对于QC,以往主要用于MyISAM存储引擎,目前在MySQL 8.0中已 放弃,对于现在非常流行的InnoDB存储引擎来讲,QC已无任何意义,因 为InnoDB存储引擎有自己的且非常完善的缓存功能。除QC之外(记录缓 存、key缓存,可使用参数单独关闭),该缓存机制还包括表缓存和权限缓 存等,这些是属于Server层的功能,其他存储引擎仍需要使用。

• Pluggable Storage Engines(插件式存储引擎):存储引擎是MySQL 84 中具体的与文件打交道的子系统,也是MySQL最具特色的一个地方。 MySQL的存储引擎是插件式的,它根据MySQL AB公司提供的文件访问层 的一个抽象接口来定制一种文件访问机制(这种访问机制就叫存储引 擎)。目前存储引擎众多,且它们的优势各不相同,现在最常用于OLTP场 景的是InnoDB(当然也支持OLAP存储引擎,但MySQL自身的机制并不擅 长OLAP场景)。

• Files& Logs(磁盘物理文件):包含MySQL的各个引擎的数据、 索引的文件,以及redo log、undo log、binary log、error log、query log、 slow log等各种日志文件。

• File System(文件系统):对存储设备的空间进行组织和分配,负 责文件存储并对存入的文件进行保护和检索的系统。它负责为用户建立文 件,存入、读出、修改、转储文件,控制文件的存取。常见的文件系统包 括XFS、NTFS、EXT4、EXT3、NFS等,通常数据库服务器使用的磁盘建 议用XFS。

        

  • 24
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值