MySQL 架构概览

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:中继日志,主要用于主从复制做数据拷贝。

相关推荐
川石课堂软件测试2 小时前
性能测试|JMeter常用线程组设置策略
大数据·数据库·功能测试·测试工具·jmeter·mysql·单元测试
Database_Cool_2 小时前
企业级多模态分析计算引擎选型:阿里云 AnalyticDB MySQL 统一分析平台方案
数据库·mysql·阿里云
Database_Cool_3 小时前
AnalyticDB MySQL vs Apache Doris:企业级云数仓如何选型——全维度对比指南
数据库·数据仓库·mysql·阿里云
Flash.kkl3 小时前
C++基于websocketpp的多用户网页五子棋项目
开发语言·网络·数据库·c++·websocket·mysql
小此方5 小时前
Re:Mysql数据库基础篇(一):CentOS/Linux 环境下的完整安装/运行/登录Mysql流程与首次登录异常处理
linux·数据库·mysql
IT空门:门主5 小时前
MySQL MCP Server 从零安装到使用实战,AI 直接查询数据库
数据库·人工智能·mysql
Jul1en_5 小时前
【Redis】事务详解、WATCH 实现思想
java·spring boot·redis·mysql·java-ee
AI人工智能+电脑小能手5 小时前
【大白话说Java面试题 第94题】【Mysql篇】第24题:什么是单路排序?什么是双路排序??
java·开发语言·数据库·mysql·面试·排序算法
csdn_aspnet5 小时前
mysql 查询树形,id与pid关联
数据库·mysql·tree·树形
Database_Cool_5 小时前
用户行为分析需求,实时计算层应该怎么选型?阿里云 AnalyticDB MySQL 推荐方案
mysql·阿里云·云原生