MySQL中mysqld服务器进程结构

MySQL中mysqld服务器进程结构_第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,结构化成表,再又连接层线程返回给用户。

MySQL中mysqld服务器进程结构_第2张图片

 

你可能感兴趣的:(MySQL)