MySQL Internal 笔记
来源:互联网 发布:房产销售软件 编辑:程序博客网 时间:2024/06/14 21:50
主要模块的交互(介绍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语句。
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来实现。
- MySQL Internal 笔记
- internal
- internal
- internal
- Android学习笔记<20140113> Internal Storage
- ABAP学习笔记三(Internal Table类型)
- Internal Server Error mysql负回收导致网站异常
- 我的学习笔记001--private protected public internal mxx
- Android开发总结笔记 External&Internal Storage 2-2
- Mysql笔记
- MySQL笔记
- mysql笔记
- MySQL笔记
- mySql 笔记
- mysql笔记
- mysql笔记
- mysql笔记
- Mysql笔记
- 用 Octave 求解线性规划问题
- gridView动态添加列
- 自动机的一些算法和应用
- for 语句
- git ignore
- MySQL Internal 笔记
- poj 2992 Divisor
- extern “C”
- win32 GDI的那点事
- Yet Another Sudoku Solver in Python
- PCA-Shift(特征点篇)
- C++模板元编程之使用模板,对数组进行“编译期间求和”
- SAP与ERPv1.0的历史数据迁移简析
- 算法实现计划