zoukankan      html  css  js  c++  java
  • MySQL服务的构成(二)

    一、什么是实例

    这里的实例不是类产生的实例对象,而是Linux系统下的一种机制

    1.MySQL的后台进程+线程+预分配的内存结构。

    2.MySQL在启动的过程中会启动后台守护进程,并生成工作线程,预分配内存结构供MySQL处理数据使用

    二、MySQL三层构成

    2.1 连接层

    1. 提供链接协议(socket,tcp/ip) #这里的socket也不是网络连接的socket,mysql的socket连接只能连接本地
    2. 验证用户的合法性(用户名,密码,白名单)
    3. 提供一个专用连接线程(接收sql,返回结果,将sql语句交给sql层继续处理)

    2.2 SQL层

    1. 接收到sql语句(判断语法、判断语义、判断语句类型[DML、DDL、DCL、DQL])
    2. 数据库对象授权检查
    3. 解析SQL语句,生成多种执行计划,MySQL没法直接执行SQL语句,必须解析成执行计划,运行执行计划,最终生成如何去磁盘找数据的方式
    4. 优化器,选择它认为成本最低的执行计划
    5. 执行器,根据优化器的选,按照优化器建议执行sql语句,得到去哪儿找sql语句需要访问的数据:A、具体在哪个数据文件上的哪个数据页中 B、将以上结果充送给下层继续处理
    6. 接收存储引擎层的数据,结构化成表的形式,通过连接层提供的专用线程,将表数据返回给用户
    7. 提供查询缓存,缓存之前查询的数据,假如查询的表是一个经常变动的表,查询缓存不要设置太大, query_cache使用memcached或Redis代替
    8. 日志记录(binlog)

     2.3 存储引擎层

    1. 接收上层的执行结果
    2. 取出磁盘文件和相应数据
    3. 返回给sql层,结构化之后生成表格,由专用线程返回给客户端

    存储引擎用于:

    1. 存储数据(将SQL语句做的修改转储到磁盘上)
    2. 检索数据(把存进去的数据在提取出来)

    双层处理 :

    1. 上层包括SQL解析器和优化器
    2. 下层包含一组储存引擎

    SQL层不依赖于存储引擎:

    1. 引擎不影响SQL处理
    2. 也有一些例外的情况

    依赖于存储引擎的功能:

    1. 存储介质
    2. 事物功能
    3. 锁定
    4. 备份和恢复
    5. 优化
    6. 特殊功能
      1. 全文检索
      2. 引用完整性
      3. 空间数据处理

    接收到sql语句,语法判断
    判断语义(判断语句类型:DML,DDL,DCL,DQL)
    解析SQL语句,生成多种执行计划
    优化器,选择它认为成本最低的执行计划(通俗讲就是选择速度快,消耗低的sql语句类型)
    执行器根据优化器的选择,按照优化器建议执行sql语句,得到去哪儿找sql语句需要访问的数据
    1.具体:在哪个数据文件上的哪个数据页中
    2.将以上结果充送给下层继续处理
    接收存储引擎层的数据,结构化成表的形式,通过连接层提供的专用线程
    提供查询缓存
    1.query_cache使用memcached或Redis代替
    日志记录(binlog)

  • 相关阅读:
    php内存管理机制、垃圾回收机制
    Redis 3.2.1集群搭建
    centos开启IPV6配置方法
    /etc/hosts.allow和/etc/hosts.deny详解
    3元购买微信小程序解决方案一个月
    linux下使用ntfs-3g挂载NTFS出错
    腾讯云微信小程序域名变更指南
    nginx开启gzip压缩
    centos 7使用yum安装docker容器
    linux中启动网卡报错:Bringing up interface eth1: Error: Connection activation failed
  • 原文地址:https://www.cnblogs.com/cyleon/p/11532674.html
Copyright © 2011-2022 走看看