系统表空间是InnoDB
数据字典、双写缓冲区、更改缓冲区和撤消日志的存储区域 。如果表是在系统表空间中创建的,而不是在每个表文件或通用表空间中创建,则它还可能包含表和索引数据。
系统表空间可以有一个或多个数据文件。默认情况下,ibdata1
会在数据目录中创建一个名为 的系统表空间数据文件 。系统表空间数据文件的大小和数量由innodb_data_file_path
启动选项定义。
ibdata1即Innodb data1的缩写,是innodb引擎的表空间,用于存放以下内容:
- 数据字典Data dictionary: 只读的表,存储对象的相关信息,如占用空间,列的缺省值,约束信息,用户名,权限,审计信息等;
- 双写缓冲区 Double write buffer:; Innodb写入数据默认是16k/pages为一个单位写入,而磁盘是4k/page一个单位,为了防止写入一半,断电无法恢复数据的情况发生,引入了double writer buffer机制;double write buffer是一段连续空间,大小2M(128 page),数据写入的时候先写到doublewrite空间,然后再写入到磁盘,如果发生写入了一个page一半的时候断电,恢复后会自动从doublewrite中恢复;
- 插入缓冲区INSERT BUFFER:针对辅助索引(非unique),插入数据的时候,先将插入的数据在buffer中根据辅助索引叶子节点的Page_no排序,而后按照Page_no分批次插入,提高性能;
- 回滚日志rollback segment: 用于存储未提交事物,便于用户rollback,当commit后,数据即被标记无效;
- undo空间 用于存放undo 日志的;用于记录事物变更前的状态,如果未commit,其他session可以查看到变更前状态
- 如果innodb_file_per_table=0,则Innodb的数据和索引也存储在ibdata中; (如果为1,则存储在表名相同的ibd和frm文件中); 如果表数据存储在ibdata中的话,那么删除表是不会释放空间;
mysql
默认配置使用
innodb
引擎
innodb_file_per_table
默认是关闭的
,
因此表空间默认建立在
ibdata1
上
1
、默认情况下
ibdata
存放
InnoDB
表(
InnoDB
数据字典)元数据、
undo logs
、
the change buffer, and the doublewrite buffer
2
、如果
innodb_file_per_table=0(
默认
=1)
,则
ibdata
也存放
InnoDB
表的实际数据,也就是
InnoDB
表建立后,不会再有单独的
tablename.ibd
文件
,
如果是
innodb_file_per_table=1,
存放
在新的表的
ibd
文件当中
3
、 虽 然
InnoDB
表 元 数 据 通 过
information_schema.tables
来 读 取 , 但 是 实 际 上
information_schema
是一个虚拟数据库,并不物理存在,这些数据真正存放的地方就是
ibdata
redo
是写在
ib_logfile
中的
,
不写在
ibdata
中。
导致ibdata1 增长很快的原因:
数据库中运行有长事务,记录了大量的UNDO信息,从而导致了ibdata1持续增长。
可以通过show engine innodb status ;命令来查看。
mysql中并未提供如何查看ibdata1中的存储内容信息。可以使用工具 innochecksum 来看。