博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
MySQL中mysqld服务器进程结构
阅读量:2337 次
发布时间:2019-05-10

本文共 422 字,大约阅读时间需要 1 分钟。

1 连接层

(1) 提供连接协议
        Socket  
        TCP/IP
(2) 验证用户名(root@localhost)密码合法性,进行匹配专门的授权表。

(3) 派生一个专用连接线程(接收SQL,返回结果)

      mysql> show processlist;

 

2 SQL层(优化方面至关重要的)

(1)验证SQL语法和SQL_MODE
(2)验证语义
(3)验证权限
(4)解析器进行语句解析,生成执行计划(解析树)
(5)优化器(各种算法,基于执行代价),根据算法,找到代价最低的执行计划。
    代价:CPU  IO  MEM
(6)执行器按照优化器选择执行计划,执行SQL语句,得出获取数据的方法。
(7)提供query cache(默认不开),一般不开,会用redis
(8)记录操作日志(binlog),默认没开

 

3 存储引擎层

真正和磁盘打交道的一个层次
根据SQL层提供的取数据的方法,拿到数据,返回给SQL,结构化成表,再又连接层线程返回给用户。

 

转载地址:http://ceepb.baihongyu.com/

你可能感兴趣的文章
指针函数与函数指针的区别
查看>>
彻底搞定C指针-函数名与函数指针
查看>>
计算机核心期刊排名
查看>>
指针数组,数组指针
查看>>
C语言指针数组和数组指针
查看>>
内存分配方式
查看>>
堆和栈的区别(转过无数次的文章)
查看>>
指针数组与数组指针
查看>>
浅谈迷途指针
查看>>
C++多态
查看>>
windows7 与 VS2005兼容
查看>>
2012年6月初的C/C++职面试经过
查看>>
C++笔试面试题 从网上整理的,带答案
查看>>
C++笔试笔记
查看>>
c++内存分配方式
查看>>
C++中const的作用
查看>>
c++中const的作用
查看>>
纯虚函数
查看>>
C++ 拷贝构造函数(深拷贝,浅拷贝)
查看>>
高质量c++(重载、覆盖、隐藏)
查看>>