MYSQL和INNODB分层实现

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 原创 水平有限 open table 的时候 当初次open table的时候会生成一个table_shared结构体 这个结构体记录 很多来自frm 的信息,基本就是表的定义,我们叫他为静态缓存 换句话说这个东西整个mysql 一个 接口为get_table_...
原创 水平有限

open table 的时候 当初次open table的时候会生成一个table_shared结构体 这个结构体记录
很多来自frm 的信息,基本就是表的定义,我们叫他为静态缓存 换句话说这个东西整个mysql 一个
接口为get_table_share
然后会每个连接线程会打开这个表的时候会根据table_shared出来的信息建立一个table结构体
这个结构体是动态的,每个会话都会建立一个,他会将实际的信息传递到innodb 层次,
最后打开innodb 的表,当然这个动态的table结构体会在table shared中有链表用来连接。
接口为open_table_from_share
请自行参考运维内参第四章,这里简单提了一下

这里主要说多态是怎么发生的。
多态成立3个条件
1、虚函数重写
2、继承
3、父类指针指向之类对象


1、
MYSQL层次和INNODB交互多态核心对象:
handler handler是基类,这个基类是在MYSQL层次的位于Handler.h中
ha_innobase: public handler  这个是继承类来自于MYSQL的handler基类,他位于innodb层,在Ha_innodb.h中
这里完成条件2


2、继承这里以open为例
在handler类中有一个函数
handler::ha_open,他里面调用了方法open比如
 if ((error=open(name,mode,test_if_locked)))
那么这里我们看看open在MYSQL层次中的定义为
  virtual int open(const char *name, int mode, uint test_if_locked)=0;
可以看到他是纯虚函数
  我们在看看Ha_innodb.cc中有这样的函数实现
  int
ha_innobase::open(
/*==============*/
const char* name, /*!< in: table name */
int mode, /*!< in: not used */
uint test_if_locked) /*!< in: not used */
)
这里完成了虚函数从写,也就完成了条件1

3、
在TABLE类中有这样一个句柄
handler *file;

在open_table_from_share会执行
outparam->file= get_new_handler(share, &outparam->mem_root,share->db_type()))) //db_type 引擎类型  db_plugin /* storage engine plugin */

if ((file= db_type->create(db_type, share, alloc)))
    file->init();
    DBUG_RETURN(file);
这里的指针是db_type->create返回的值,这里的db_type为innobase,这里db_type->create为一个函数指针
handler *(*create)(handlerton *hton, TABLE_SHARE *table, MEM_ROOT *mem_root);
他指向了
handler* innobase_create_handler(handlerton* hton, /*!< in: InnoDB handlerton */ TABLE_SHARE* table,MEM_ROOT* mem_root)

通过这里outparam->file已经指向了一个引擎层次的一个具体化的实例,这里完成条件3父类指针指向之类对象
也就是handler指针指向了ha_innobase

那么这里3个条件都已经满足,多态发生了

下面以open 为例,我们知道这个open函数在innodb 层次已经虚函数重写

在open_table_from_share的最后会实际的打开表
if ((ha_err= (outparam->file->
                  ha_open(outparam, share->normalized_path.str,
                          (db_stat & HA_READ_ONLY ? O_RDONLY : O_RDWR),
                          (db_stat & HA_OPEN_TEMPORARY ? HA_OPEN_TMP_TABLE :
                           (db_stat & HA_WAIT_IF_LOCKED) ?
                           HA_OPEN_WAIT_IF_LOCKED :
                           (db_stat & (HA_ABORT_IF_LOCKED | HA_GET_INFO)) ?
                          HA_OPEN_ABORT_IF_LOCKED :
                           HA_OPEN_IGNORE_IF_LOCKED) | ha_open_flags))))
我们主要关注下这里的多态
我们知道ha_open实际会调用open,open在innodb层次已经重写,而outparam->file正是这样一个
指针,他指向了innodb层的具体实例,当ha_open中执行
if ((error=open(name,mode,test_if_locked)))
就已经调用了innodb层次的ha_innobase::open,完成了层次的划分,也是模块的划分。其实一切
都是以C/C++多态的基础实现的。



作者微信:

               
相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
相关文章
|
3月前
|
存储 关系型数据库 MySQL
介绍MySQL的InnoDB引擎特性
总结而言 , Inno DB 引搞 是 MySQL 中 高 性 能 , 高 可靠 的 存 储选项 , 宽泛 应用于要求强 复杂交易处理场景 。
136 15
|
8月前
|
存储 网络协议 关系型数据库
MySQL8.4创建keyring给InnoDB表进行静态数据加密
MySQL8.4创建keyring给InnoDB表进行静态数据加密
253 1
|
12月前
|
存储 缓存 关系型数据库
【MySQL进阶篇】存储引擎(MySQL体系结构、InnoDB、MyISAM、Memory区别及特点、存储引擎的选择方案)
MySQL的存储引擎是其核心组件之一,负责数据的存储、索引和检索。不同的存储引擎具有不同的功能和特性,可以根据业务需求 选择合适的引擎。本文详细介绍了MySQL体系结构、InnoDB、MyISAM、Memory区别及特点、存储引擎的选择方案。
1951 57
【MySQL进阶篇】存储引擎(MySQL体系结构、InnoDB、MyISAM、Memory区别及特点、存储引擎的选择方案)
|
8月前
|
SQL 缓存 关系型数据库
使用温InnoDB缓冲池启动MySQL测试
使用温InnoDB缓冲池启动MySQL测试
147 0
|
12月前
|
存储 关系型数据库 MySQL
MySQL存储引擎详述:InnoDB为何胜出?
MySQL 是最流行的开源关系型数据库之一,其存储引擎设计是其高效灵活的关键。InnoDB 作为默认存储引擎,支持事务、行级锁和外键约束,适用于高并发读写和数据完整性要求高的场景;而 MyISAM 不支持事务,适合读密集且对事务要求不高的应用。根据不同需求选择合适的存储引擎至关重要,官方推荐大多数场景使用 InnoDB。
481 7
|
3月前
|
缓存 关系型数据库 BI
使用MYSQL Report分析数据库性能(下)
使用MYSQL Report分析数据库性能
147 3
|
3月前
|
关系型数据库 MySQL 数据库
自建数据库如何迁移至RDS MySQL实例
数据库迁移是一项复杂且耗时的工程,需考虑数据安全、完整性及业务中断影响。使用阿里云数据传输服务DTS,可快速、平滑完成迁移任务,将应用停机时间降至分钟级。您还可通过全量备份自建数据库并恢复至RDS MySQL实例,实现间接迁移上云。
|
4月前
|
存储 运维 关系型数据库
从MySQL到云数据库,数据库迁移真的有必要吗?
本文探讨了企业在业务增长背景下,是否应从 MySQL 迁移至云数据库的决策问题。分析了 MySQL 的优势与瓶颈,对比了云数据库在存储计算分离、自动化运维、多负载支持等方面的优势,并提出判断迁移必要性的五个关键问题及实施路径,帮助企业理性决策并落地迁移方案。
|
3月前
|
关系型数据库 MySQL 分布式数据库
阿里云PolarDB云原生数据库收费价格:MySQL和PostgreSQL详细介绍
阿里云PolarDB兼容MySQL、PostgreSQL及Oracle语法,支持集中式与分布式架构。标准版2核4G年费1116元起,企业版最高性能达4核16G,支持HTAP与多级高可用,广泛应用于金融、政务、互联网等领域,TCO成本降低50%。
|
3月前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS费用价格:MySQL、SQL Server、PostgreSQL和MariaDB引擎收费标准
阿里云RDS数据库支持MySQL、SQL Server、PostgreSQL、MariaDB,多种引擎优惠上线!MySQL倚天版88元/年,SQL Server 2核4G仅299元/年,PostgreSQL 227元/年起。高可用、可弹性伸缩,安全稳定。详情见官网活动页。