主要模块的交互(介绍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来实现。C# 操作PostgreSQL 数据库Oracle数据库Decode()函数的使用方法相关资讯 MySQL基础
- MySQL因为区分大小写而引起找不到 (09/08/2012 20:12:21)
- MySQL 执行计划解读 (09/07/2012 06:18:14)
- MySQL的“[Warning] Invalid (old? (08/09/2012 08:55:01)
| - MySQL 版本选择 (09/07/2012 06:18:58)
- MySQL审计插件安装使用说明文档-- (08/09/2012 08:57:10)
- MySQL审计插件安装使用说明文档 (08/09/2012 08:50:33)
|
本文评论 查看全部评论 (0)