The All-in-One Note (18)

在创建过程中Channel会去EventLoopGroup中申请注册一个EventLoopChannelEventLoopGroup是多对一的关系,EventLoop对应一个Reactor线程模型

注册完成后Channel就可以执行ChannelpipeLine中的任务了

ChannelpipeLine由各种Handler组成,主要有ChannelInboundHandler(读)和ChannelOutboundHandler(写),通过HandlerContext管理,各大Handler可以通过ByteBuf操作数据

数据库 Mysql 基本架构

MySQL 主要分为 Server 层和存储引擎层

Server 层:主要包括连接器、查询缓存、分析器、优化器、执行器等,所有跨存储引擎的功能都在这一层实现,比如存储过程、触发器、视图,函数等,还有一个通用的日志模块 binglog 日志模块。

存储引擎: 主要负责数据的存储和读取,采用可以替换的插件式架构,支持 InnoDB、MyISAM、Memory 等多个存储引擎,其中 InnoDB 引擎有自有的日志模块 redolog 模块。现在最常用的存储引擎是 InnoDB,它从 MySQL 5.5.5 版本开始就被当做默认存储引擎了。

组件介绍

连接器: 身份认证和权限相关(登录 MySQL 的时候)

查询缓存: 执行查询语句的时候,会先查询缓存(MySQL 8.0 版本后移除,因为这个功能不太实用)

分析器: 没有命中缓存的话,SQL 语句就会经过分析器,分析器说白了就是要先看你的 SQL 语句要干嘛,再检查你的 SQL 语句语法是否正确

优化器: 按照 MySQL 认为最优的方案去执行

执行器: 执行语句,然后从存储引擎返回数据

SQL执行过程

查询等过程如下:

权限校验---》查询缓存---》分析器---》优化器---》权限校验---》执行器---》引擎

更新等语句执行流程如下

分析器----》权限校验----》执行器---》引擎---redo log prepare---》binlog---》redo log commit

MyISAM和InnoDB区别

是否支持行级锁 : MyISAM 只有表级锁(table-level locking),而InnoDB 支持行级锁(row-level locking)和表级锁,默认为行级锁。

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/wpyysp.html