使用独立表空间后,系统表空间存储什么内容呢?
1.innodb 数据字典信息
和存储引擎相关。
frm 是服务器的数据字典和存储引擎无关。
2. undo 回滚段。
可以单独存储。
INNODB存储引擎特性
1.事务性存储引擎。
2.支持ACID特性
redo log 和 undo log
redo log 实现事务的持久性。
包括两部分:
1.内存中的重做日志缓冲区。
2.文件系统的 ib_logfilex.
show variables like ‘innodb_log_buffer_size’ 字节为单位。
内存中 默认 16M.
数量由参数innodb_log_files_in_group决定。
redo log 存放的是提交的事务,undolog 存放的是未提交的事务。
undo log 作用:
1.用于回滚
2.多版本并发控制 (Multi-Version Concurrency Control )
当对表中的数据进行修改时不仅产生redolog 也会产生一定的undo log。
使用rollback时会用到undolog。
redo log 为顺序写入,在数据库运行时不需要读取操作。
undo log 需要随机读写。可以存放于SSD 上提升性能。
2.INNODB 支持行级锁。
行级锁可以最大程度支持并发。
行级锁在存储引擎层实现。
什么是锁?
锁主要作用是管理共享资源的并发访问,用于实现事务的隔离性。
锁的类型
共享锁(读锁)
读锁相互不会被阻塞。
独占锁 (写锁)
会阻塞其他的读锁和写锁。实现事务隔离性。
锁的粒度
1.表级锁
lock table myinnodb write;
这样就会阻塞其他读取。
unlock tables;
2.行级锁
在存储引擎实现,不在服务器层实现。
阻塞和死锁
什么是阻塞?
一个事务中的锁需要等待另外一个事务锁的资源释放。
什么是死锁?
相互占用对方的等待资源,可以由系统自动处理。
1.按照相同的顺序使用资源。
2.增加相关的索引。
3.innodb 状态检查。
show engine innodb status; 两次需要至少间隔30秒。
4.适用场景
innodb 适合大多数的OLTP应用,支持全文索引和空间函数。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· winform 绘制太阳,地球,月球 运作规律
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人