使用独立表空间后,系统表空间存储什么内容呢?
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应用,支持全文索引和空间函数。