MySQL总览-结构图(一)

MySQL架构图 【MySQL总览-结构图(一)】MySQL总览-结构图(一)
文章图片

架构分层

  • 客户端连接层
    与客户端交互,支持的协议,如Java中的JDBC
  • 服务层
    MySQL总览-结构图(一)
    文章图片

    • 连接池
      主要负责存储和管理客户端与数据库的连接,一个线程负责管理一连接,对于连接数多的(>128)性能极大提升。
    • 缓存
      MySQL中也是有缓存存在,类似Redis并且也是KV形式储存在内存,但是用的很少。
      MySQL拿到一个查询请求后,会先查询缓存,命中就会直接返回结果。缓存未命中,继续执行并且在执行完成后,将结果存入缓存中。
      弊端:数据库上一条数据更新,就会导致缓存失效,更新频繁的数据库,查询缓存的命中率非常低。(可设置参数query_cache_type选择是否使用缓存,在MySQL8.0以后将查询缓存删除了,不在有缓存功能)
  • 解析器
    执行语句。对SQL语句进行解析。类似编译原理中的词法分析、语法分析等。
  • 优化器
    经解析器分析完后进入优化器,对SQL进行优化。
    主要是存在数据库表中,存在多个索引,使用具体哪个索引问题,或者多表关联join。决定各个表的连接顺序。
    处理完成后,确定了SQL的执行方案。
  • 执行器
    优化器完成进入执行器。首先查看是否有权限执行,若有,打开表继续执行,并根据表的引擎定义,使用该引擎提供的接口。
  • 存储引擎层
    MySQL总览-结构图(一)
    文章图片

    不是所有的关系型数据库都有存储引擎概念。
    数据库管理系统使用数据库引擎进行创建、查询、更新和删除数据。不同的引擎有不同的存储、处理数据的机制。
    MySQL5.5以前默认是MyISAM
    MySQL5.5之后是InnoDB
    MySQL总览-结构图(一)
    文章图片

    • MyISAM与InnoDB区别
      • InnoDB支持行锁,MyISAM使用表锁
      • InnoDB支持ACID兼容的事务。
      • InnoDB支持外键。
      • InnoDB支持系统崩溃后的安全恢复
      • InnoDB支持MVCC
      • ...
    很多已知的场景中InnoDB的速度都是远超MyISAM,尤其是用到聚簇索引,或者需要访问的数据都可以放入内存中的应用
  • 系统文件存储层
    MySQL总览-结构图(一)
    文章图片

    系统文件存储层主要是负责将数据库的数据和日志存储在系统的文件中,同时完成与存储引擎的之间的打交道,是文件的物理存储层。比如:数据文件、日志文件、pid文件、配置文件等。
    • 配置文件
      my.ini、my.cnf等
    • 数据文件
    • 日志文件
      错误日志
      二进制日志 binary log
      慢查询日志
      通用查询日志
      ...

    推荐阅读