innodb 存储引擎特性
2018-06-17 23:03:44来源:未知 阅读 ()
使用独立表空间后,系统表空间存储什么内容呢?
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应用,支持全文索引和空间函数。
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
- MySQL如何存储IP地址 2019-10-25
- MySQL存储引擎总结 2019-09-23
- Session的生成机制、回收机制和存储机制详解 2019-08-26
- 太太太太太太高兴了,GitHub私有存储库免费啦 2019-08-09
- 【mysql】mysql中的锁机制 2019-07-24
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash