MySQL Internal 笔记

php中文网
发布: 2016-06-07 17:19:38
原创
1440人浏览过

主要模块的交互(介绍mysql各个模块主要职责),当Connection Manager收到client连接的时候,则会初始化网络连接进程,然后建立C

主要模块的交互(介绍mysql各个模块主要职责)

当Connection Manager收到client连接的时候,则会初始化网络连接进程,然后建立Connetion handler进程。进而connection handler进程进行权限认证。

传过来的sql脚本将会被Command Dispatcher接收,如果是个复杂的指令,将会传到其他的模块去。

在Mysql的术语中,client有两种请求,一种是query,另外一种是command,query不仅包括select,还包括delete、insert等,这些语句是需要经过parser处理的,而command则不需要经过parser处理。

如果开启了query logging,那么command dispatcher 将会让logging module来做日志。

command dispatcher在使用parser之前,首先会调用query cache,query cache首先检查该query是不是可以被cache,是否有符合该query的数据已经被cache,如果有的话,就返回,如果miss了,就会执行parser。

执行好parser之后,,select由optimizer来处理;update、 inserts、 deletes和table创建语句,schema创建语句 schema alter语句由table modification module来处理;其他还有table maintenance module,replication module等等。

然后通过维护着table list的access control module,进入到Table manager,打开表并获取相应的锁,然后调用相应的引擎,实现query语句。

Get笔记
Get笔记

Get笔记,一款AI驱动的知识管理产品

Get笔记 125
查看详情 Get笔记

abstracted storage engine module自动将query转化为对应引擎的方法进行处理。

在query语句执行的时候,corresponding module会把一些结果集返回到client。

Mysql没有使用exceptions,因此在任何一层都需要使用错误检测语句。

当一个任务完成后,就会返回到connection module去等待新的任务。

slave也可能会读取二进制更新文件,这将会由master节点来负责。

如果一台机器被定义为slave,那么将会启动两个线程,一个是sql thread,另外一个是i/o线程。

网络连接将会通过Client/server protocol module来实现。而mysql的核心功能都由Core api来实现。

linux

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号