Mysql 的原理

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
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值