MySQL 架构概览

embedded/2024/11/21 15:58:34/


show processlist;命令查询所有正在运行的线程

MySql架构从上到下分为网络连接层,系统服务层,存储引擎层,文件系统层
1.网络连接层主要负责维护客户端的连接,保存session会话,以及多线程下的连接管理。

2.系统服务层,主要功能包括提供SQL查询的API,以及其他所有跨存储引擎的功能,具体组件包括解析器,优化器,缓存区
解析器是进行语法权限等分析和翻译的,优化器可以生成执行计划,缓存区是为了加快查询效率而存在

3.存储引擎层,是与磁盘打交道的子系统,负载管理表,索引的管理

4.文件系统层,所有文件的读写,包括表结构文件,数据文件,索引文件,日志文件等


关于MySQL连接池和线程池的问题
生产环境客户端连接一般会使用连接池,主要维护的是网络连接;MySQL线程池维护的是工作线程,它位于MySQL服务器的网络连接层。
也就是客户端发起SQL请求时,先是在客户端程序中获取空闲连接,如果没有则创建新的TCP连接,然后服务端这边进行账号校验,接着判断是否有空闲工作线程并安排执行任务。


日志文件主要有以下几种:
1.binlog二进制日志,主要记录MySQL数据库的所有写操作(增删改)。
2.redo-log重做/重写日志,MySQL崩溃时,对于未落盘的操作会记录在这里面,用于重启时重新落盘(InnoDB专有的)。
3.undo-logs撤销/回滚日志:记录事务开始前[修改数据]的备份,用于回滚事务。
原理为:它会在ibdata文件中拷贝修改前的数据,并将文件位置记录在表行数据因此字段roll_ptr中,如果回滚则从ibdata拷贝原内容到ibd文件中实现回滚。
如果一个事务有多个该行数据的修改,则通过roll_ptr回滚指针,组成一个单向链表,这个是MVCC机制实现的关键。
4.error-log:错误日志:记录MySQL启动、运行、停止时的错误信息。
5.general-log常规日志,主要记录MySQL收到的每一个查询或SQL命令。
6.slow-log:慢查询日志,主要记录执行时间较长的SQL。
7.relay-log:中继日志,主要用于主从复制做数据拷贝。

 


http://www.ppmy.cn/embedded/139377.html

相关文章

【Vim/Vi/Gvim操作】:列操作

文章目录 列操作1. 列选择模式1.1 visual 模式1.2 visual line模式1.3 visual block模式 2.列操作2.1 行首插入操作2.2 替换操作 列操作 1. 列选择模式 1.1 visual 模式 命令行状态下按下小写v,默认进入到visual模式,该模式相当于在window中按下鼠标左…

经典面试力扣392判断子序列

给定字符串s和t,判断s是否为t的子序列。 字符串的一个子序列是原始字符串删除一些(也可以不删除) 字符而不改变剩余字符相对位置形成的新字符串。 (例如,"ace"是"abcde"的一个子序列,而"aec"不是)。…

静态时序分析--时序约束

目录 1.时钟约束1.1创建时钟1.2.生成时钟1.3虚拟时钟1.4 最小时钟脉宽 2.I/O延时约束2.1设置输入延时2.2设置输出延时 3.I/O环境建模约束3.1输入驱动建模3.2输出负载建模 4.时序例外4.1多周期路径设置(multicycle path)4.2伪路径设置(false_p…

Mybatis-Plus 多租户插件属性自动赋值

文章目录 1、Mybatis-Plus 多租户插件1.1、属性介绍1.2、使用多租户插件mavenymlThreadLocalUtil实现 定义,注入租户处理器插件测试domianservice & ServiceImplmapper 测试mapper.xml 方式 1.3、不使用多租户插件 2、实体对象的属性自动赋值使用1. 定义实体类2. 实现 Meta…

【WRF-Urban】URBPARM_LCZ.TBL 查找表解释及内容

【WRF-Urban】URBPARM_LCZ.TBL 查找表解释及内容 URBPARM_LCZ.TBL 文件的作用URBPARM_LCZ.TBL 文件中的参数URBPARM_LCZ.TBL 的使用URBPARM_LCZ.TBL 文件内容如何调整或扩展 URBPARM_LCZ.TBL参考URBPARM_LCZ.TBL 文件是 WRF(天气研究与预报模型) 中用于处理 局地气候区(Loca…

很能体现FPGA硬件思维的一道面试题

在面试的时候,要在短时间检查一个人的水平,需要面试官有针对性的问些问题,这里举例说一个很能体现FPGA硬件思维的一道面试题。 if-else及case语句条件判断的优先级 这里先列出几个例子,大家可以先自行判断以下: exampl…

探索Linux软件包管理的进化之路:从源码编译到Snap包的飞跃

目录 引言一、Linux软件包管理的发展过程1、从源代码安装软件2、使用软件包安装软件3、高级软件包管理工具 二、Deb软件包管理1、查看2、安装3、卸载 三、 使用APT工具管理软件包1、基本功能2、解决依赖关系3、软件包更新4、查询软件包5、安装软件包6、卸载软件包7、升级软件包…

前端三剑客(二):CSS

目录 1. CSS 基础 1.1 什么是 CSS 1.2 语法格式 1.3 引入方式 1.3.1 行内样式 1.3.2 内部样式 1.3.3 外部样式 1.4 CSS 编码规范 2. 选择器 2.1 标签选择器 2.2 id 选择器 2.3 class 选择器(类选择器) 2.4 复合选择器 2.5 通配符选择器 3. 常用 CSS 样式 3.1 c…