mysql服务器结构_MySQL中mysqld服务器进程结构

5947b23c90720481750ee7180e0578a3.png

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,结构化成表,再又连接层线程返回给用户。

ec35c1b5e2d72b61cd453b8dbf6fb911.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值