Mysql是我们常见的存储引擎,下面总结一下我认知的Mysql。
一、mysql基础架构
1、连接器管理
首先是数据库连接器,主要负责和客户端建立连接、权限获取、管理连接等,由于整个建连的过程比较复杂,所以尽量使用长连接。如果数据库发生异常后为了快速恢复,可重启系统重新建立连接。
2、Mysql缓存
mysql请求首先看缓存数据,key为sql语句value为查询的结果,如果存在则直接返回。如果没有则直接往下走。
注意:mysql缓存对于一些静态数据比较适合,对于实时性高的数据最好不要使用。
3、分析器
对你执行的sql语句进行解析,首先是词法分析包括一些关键字识别,然后语法分析,查看这条语句是否符合mysql语句
4、优化器
通过你的语句分析,发现那些查询命中索引,还有表之间的连接顺序等
5、执行器
通过上面一系列的验证,使用引擎提供的接口。经过不断的执行将查询的结果存放在结果集中,通过explain可以看到执行器具体扫描了多少行。
二、sql语句的执行流程
首先要清楚redo log和binlog两个日志模块
1、redo log(InnoDB特有的日志模块) 重做日志文件,用于记录事务操作的变化,记录修改后的值,不管事务是否提交。保证数据的完整性。其中redo log是固定大小的,是从头开始写,写到末尾在从头开始。同时会有两个指针,一个记录写入的位置,一个标记,当前擦除的位置,不断的循环。整个过程称为crash-safe。即时数据库异常,也会有记录
2、binlog 归档日志文件,用于记录对mysql数据库执行更改的所有操作。binlog是追加写,不会覆盖之前的。
接下来介绍一下mysql更新一条语句的流程。
update tb_area SET area_name = "beijing" WHERE area_id = 1
1) 首先执行器通过id查到这条记录(搜索树或者查找数据页) ,并加载到内存中。
2)然后对这条记录的area_name调用引擎写入接口,进行修改。
3)修改内存中的值,同时更新redolog告知执行器完成写入(状态置为prepare),可以提交事务,执行器将这条操作记录记录在binlog,写入磁盘
4)完成上述一系列的操作,执行器调用事务提交接口(redolog状态置为commit),完成更新操作。
注意:Mysql的redolog模块写入拆成2步走,prepare和commit,称为两阶段提交。 整个过程为1、redolog的prepare状态 2、binlog的写入 3、redolog的commit状态,保证Mysql的可靠性。
如果binlog没有写入并没有提交事务回滚
如果binlog写入事务没提交,数据库回复后自动完成commit