一、mysql结构
1.实例
1.什么是单实例
一个进程 + 多个线程 + 一个预分配的内存空间
2.多实例
多个进程 + 多个线程 + 多个预分配的内存空间
2.mysql程序结构
1)连接层
1.验证用户身份
2.提供两种连接方式
3.与sql层建立线程
2)sql层
1.接收连接层发过来的sql语句
2.判断sql的语法
3.判断sql的语义
4.解析器:解析sql语句,生成执行计划
5.优化器:选择最优执行计划
6.执行器:执行选择出来的计划,SQL
6.1 与存储引擎层建立交互,将sql语句传给存储引擎层
6.2 将存储引擎层传来的数据以表格的形式展示出来
7.将数据写入缓存
8.记录日志
3)存储引擎层
1.与sql层建立交互,接收sql层传来sql语句
2.与磁盘建立交互,获取数据
3.mysql逻辑结构
1.库:库的下面全是表
2.表:元数据 + 真实数据行
3.元数据:列 + 其它属性(行数+占用空间大小+权限)
4.列:列名字 + 数据类型 + 其他约束(非空、唯一、主键、非负数、自增长、默认值)
4.mysql物理结构
1.MySQL的最底层的物理结构是数据文件,也就是说,存储引擎层,打交道的文件,是数据文件。
2.存储引擎分为很多种类(Linux中的FS)
3.不同存储引擎的区别:存储方式、安全性、性能
数据库创建时,不论库名还是表名,尽量都用小写字母
5.mysql物理大小
1.段:理论上一个表就是一个段,由多个区构成,(分区表是一个分区一个段)
2.区:连续的多个页构成
3.页:最小的数据存储单元,默认是16k
4.分区表:一个区构成一张段,就是一张表
二、mysql的多实例
1.创建多实例目录
#mysql 多实例,也是多个配置文件启动数据库
mysql多个配置文件:
1.多个端口
2.多个socket文件
3.多个日志文件
4.多个srver_id
5.多个数据目录
[root