0

0

mysql表空间是什么_mysql数据存储结构

P粉602998670

P粉602998670

发布时间:2026-01-04 13:55:02

|

911人浏览过

|

来源于php中文网

原创

表空间是InnoDB组织物理文件与内存页的逻辑容器,对应ibdata1(系统)、.ibd(独立/通用)、undo_*.ibu(撤销)、ibtmp1(临时)等文件,不包括redo log和binlog。

mysql表空间是什么_mysql数据存储结构

表空间 是 InnoDB 存储引擎中数据存储的逻辑容器,不是文件夹、也不是数据库,而是把物理磁盘文件(如 ibdata1xxx.ibd)和内存中页(page)、区(extent)、段(segment)组织起来的一套抽象结构。它直接决定了你的数据怎么落盘、怎么读取、怎么备份、甚至崩溃后能不能恢复。


表空间到底对应哪些物理文件?

不同类型的表空间,背后是完全不同的文件形态:

  • 系统表空间:默认只有一个文件 ibdata1(有时带 ibdata2 等),存着数据字典、undo 日志(旧版本)、change buffer、还有可能包含用户表数据(如果没开 innodb_file_per_table
  • 独立表空间:每个 CREATE TABLE ... ENGINE=InnoDB 表默认生成一个 数据库名/表名.ibd 文件(例如 /var/lib/mysql/test/t_user.ibd),表数据 + 索引全在里面
  • 通用表空间:由 CREATE TABLESPACE ts_name ADD DATAFILE 'ts_name.ibd' 创建,可手动把多个表 ALTER TABLE t1 TABLESPACE ts_name 迁入,共享一个 .ibd 文件
  • 撤销表空间:MySQL 8.0+ 默认启用多个独立 undo_001.ibu 文件,用于事务回滚,可配置为自动扩展或固定大小
  • 临时表空间:通常是 ibtmp1(位于 innodb_temp_data_file_path 指定路径),只存 CREATE TEMPORARY TABLE 和内部排序/聚合产生的临时数据

⚠️ 注意:ib_logfile0/1redo log)和 mysql-bin.*(binlog)不属于表空间,它们是日志系统独立管理的文件。


为什么默认开启 innodb_file_per_table

这是 MySQL 5.6+ 的默认值(ON),核心原因就三个字:可回收

  • 关掉它(OFF):所有表都往 ibdata1 里塞 → DROP TABLEibdata1 永不缩小,磁盘空间无法释放
  • 开启它(ON):每张表一个 .ibdDROP TABLE 后文件直接删除,空间立刻归还文件系统
  • 还能单独对某张大表做 OPTIMIZE TABLEALTER TABLE ... REBUILD 来收缩空间,不影响其他表

如果你发现 ibdata1 膨胀到几百 GB 却删不掉,八成是早期建库时没开这个选项,且已有大量表在系统表空间里 —— 这种情况迁移成本极高,需导出再重建。

Morph Studio
Morph Studio

Morph Studio是一款领先的文字转视频AI平台,可以将用户输入的文字转化为精美视频。

下载

表空间里的数据到底是怎么组织的?

InnoDB 不是以“行”或“列”为单位存数据,而是按层级结构组织:

  • 页(Page):最小 I/O 单位,默认 16KB(由 innodb_page_size 决定),INDEX 类型页存 B+ 树节点(含聚簇索引/二级索引),BLOB 页存溢出的大字段
  • 区(Extent):连续 64 个页 = 1MB,分配空间时以区为单位(避免页碎片导致随机 IO)
  • 段(Segment):逻辑概念,比如一张表的聚簇索引分两个段 —— 叶子节点段(存真实记录)和 非叶子节点段(存目录页),各自从不同区申请空间

所以你执行 SELECT * FROM t LIMIT 1,InnoDB 实际上是从表空间里找到聚簇索引的根页 → 定位到某个叶子区 → 加载整页(16KB)进 Buffer Pool → 再从页里解析出那一条记录。不是“读一行”,而是“读一页”。


常见误操作与修复场景

表空间问题往往表现为错误信息直击要害,但根源常被忽略:

  • ERROR 1114 (HY000): The table 't' is full:不是磁盘满,而是该表所在表空间(比如 t.ibd)已达到 innodb_data_file_path 设置的上限,或文件系统满。查 df -hls -lh *.ibd
  • Tablespace is missing for table `db`.`t`.ibd 文件被误删,但 frm 还在 → ALTER TABLE t DISCARD TABLESPACE + 手动拷回 .ibd + IMPORT TABLESPACE(需严格匹配表结构、checksum、server_uuid)
  • InnoDB: Failing assertion: page_no == 0:表空间头损坏(FSP_HDR 页异常),mysqlcheck --repair 通常无效,得靠备份恢复;预防手段是开启 innodb_checksum_algorithm=crc32 + 定期校验

真正棘手的从来不是“怎么扩容”,而是“哪张表在哪个表空间里、它的物理文件是否还在、有没有被硬链接或 mount bind 遮蔽”——这些细节一漏,mysqld 启不起来,连错误日志都打不出来。

相关专题

更多
mysql修改数据表名
mysql修改数据表名

MySQL修改数据表:1、首先查看数据库中所有的表,代码为:‘SHOW TABLES;’;2、修改表名,代码为:‘ALTER TABLE 旧表名 RENAME [TO] 新表名;’。php中文网还提供MySQL的相关下载、相关课程等内容,供大家免费下载使用。

657

2023.06.20

MySQL创建存储过程
MySQL创建存储过程

存储程序可以分为存储过程和函数,MySQL中创建存储过程和函数使用的语句分别为CREATE PROCEDURE和CREATE FUNCTION。使用CALL语句调用存储过程智能用输出变量返回值。函数可以从语句外调用(通过引用函数名),也能返回标量值。存储过程也可以调用其他存储过程。php中文网还提供MySQL创建存储过程的相关下载、相关课程等内容,供大家免费下载使用。

244

2023.06.21

mongodb和mysql的区别
mongodb和mysql的区别

mongodb和mysql的区别:1、数据模型;2、查询语言;3、扩展性和性能;4、可靠性。本专题为大家提供mongodb和mysql的区别的相关的文章、下载、课程内容,供大家免费下载体验。

280

2023.07.18

mysql密码忘了怎么查看
mysql密码忘了怎么查看

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql密码忘了怎么办呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

514

2023.07.19

mysql创建数据库
mysql创建数据库

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql怎么创建数据库呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

252

2023.07.25

mysql默认事务隔离级别
mysql默认事务隔离级别

MySQL是一种广泛使用的关系型数据库管理系统,它支持事务处理。事务是一组数据库操作,它们作为一个逻辑单元被一起执行。为了保证事务的一致性和隔离性,MySQL提供了不同的事务隔离级别。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

386

2023.08.08

sqlserver和mysql区别
sqlserver和mysql区别

SQL Server和MySQL是两种广泛使用的关系型数据库管理系统。它们具有相似的功能和用途,但在某些方面存在一些显著的区别。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

526

2023.08.11

mysql忘记密码
mysql忘记密码

MySQL是一种关系型数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。那么忘记mysql密码我们该怎么解决呢?php中文网给大家带来了相关的教程以及其他关于mysql的文章,欢迎大家前来学习阅读。

595

2023.08.14

AO3中文版地址汇总
AO3中文版地址汇总

本专题整合了AO3中文版地址合集,阅读专题下面的文章了解更多详细内容。

0

2026.01.06

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 1.6万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 780人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号