MySQL 独立表空间与共享表空间总结

MySQL 独立表空间与共享表空间总结

本文是参考了这些文章做的梳理:
http://blog.itpub.net/69955379/viewspace-2783174/
https://www.ycbbs.vip/?p=35673

1. 独立表空间与共享表空间

对于 InnoDB 存储引擎,它可以将每张表存放于独立的表空间,即 tablename.ibd 文件;也可以将数据存放于 ibdata 的共享表空间,一般命名是 ibdataX,后面的 X 是一个具体的数字。

  • 如何查看是否开启了独立表空间?:

    mysql> show variables like 'innodb_file_per_table';
    +-----------------------+-------+
    | Variable_name         | Value |
    +-----------------------+-------+
    | innodb_file_per_table | ON    |
    +-----------------------+-------+
    1 row in set (0.01 sec)
    
    
    • ON 则代表已经开启了独立表空间,此时在 MySQL的 data-dir 目录下
      • 每个表将会以独立文件的方式来进行存储,每一个表都有一个 .frm 表描述文件(这个和 MyISAM 引擎一致),还有一个 .ibd 文件,这个文件包括了单独一个表的数据内容以及索引内容,默认情况下它的存储位置也是在表的位置之中。
    • OFF 则表示关闭独立表空间,也就是使用共享表空间,此时在 MySQL的 data-dir 目录下只会存在一个 ibdata1 文件,所有表都集中存储在一个文件下。
    • 需要注意的是,innodb_file_per_table 要在创建表之前修改,创建表之后再去修改,是不会影响已有的表结构的。
1.1 独立表空间与共享表空间的优缺点

独立表空间

  • 优势

    1. 每张表都有自己独立的表空间。
    2. 每张表的数据和索引都会存储在自己的表空间中。
    3. 可以实现单表在不同的数据库中移动(因为每张表都有独立的数据表文件)。
    4. 空间可以回收(通过 optimize table 等命令实现)。
    5. 无论怎么删除,表空间的碎片不会太严重影响系统性能。
    6. 不启用innodb_file_per_table,数据都会放在系统表空间中,最大64TB,如果使用innodb_file_per_table每个表可以64TB。
  • 缺点

    1. 表空间中的空间只能被这个表使用
    2. fsync操作必须在每个表上都运行一遍
    3. mysqld必须保持一个打开的文件句柄,表太多会影响性能。(消耗很多 fd)

共享表空间

  • 优势

    1. 可以将表空间分成多个文件存放到各个磁盘上(表空间文件大小不受表大小的限制,如一个表可以分布在不同的文件上)。
  • 缺点

    1. 所有的数据和索引存放到一个文件中,这将意味着有一个很大的文件存在(虽然可以把一个大文件分成多个小文件),但是多个表及索引在表空间中混合存储,这样当一个表做了大量删除操作后表空间中将会有大量的空隙,特别是对于统计分析、日志系统这类应用而言,最不适合用共享表空间(例如,当系统空间不够用的时候,我们希望通过删除一些无效数据来腾出来一些表空间,这个时候我们会发现,如果使用了共享表空间,即使无效数据删除了,表空间还是还是不会缩小)。

    2. 共享表空间管理会出现表空间分配后不能回缩的问题,当临时建立索引或者临时表导致表空间扩大后,就是删除相关的表也没办法回缩那部分空间了。

    3. 对于第二点存在的问题,一般使用 mysqldump 导出数据,然后删除共享表空间数据文件后,再重新导入。

    4. 由于一个文件中保存了多个表数据,所以并发操作时可能会产生 IO 瓶颈,所以需要频繁写入的场景并不适合共享表空间。

在实际项目中,还是首选独立表空间比较好,事实上,从 MySQL5.6 开始,独立表空间就已经成为默认选项了

1.2 如何转换共享表空间的数据到独立表空间

如果一开始创建的是共享表空间,那么还能迁移到独立表空间吗?当然可以!参考如下四个步骤:

  1. 使用 mysqldump 导出所有数据库表数据。
  2. 停止 MySQL 服务,修改 innodb_file_per_table 参数,并删除 InnoDB 相关文件(如果是主从结构,则可以从 Slave 上入手完成这些操作)。
  3. 重启 MySQL 服务,重建 InnoDB 共享表空间(此时里边就没有数据了)。
  4. 重新导入数据。
  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL提高存储空间有几种方法可以考虑。首先,InnoDB引擎可以选择使用共享空间独立空间。建议使用独立空间,因为它更便于管理和维护。通过启用innodb_file_per_table选项,可以在线动态地修改生效,这样每个都有自己的空间,可以更灵活地管理存储空间。 其次,您还可以考虑使用mysql-binuuid-rails插件。这个插件允许您在模型上定义UUID类型的属性,并将UUID作为二进制值存储在数据库中。同时,仍然可以使用字符串示形式进行查询。这种方式可以节省存储空间,尤其是在存储大量UUID值的情况下。 最后,您还可以通过优化和压缩数据来提高存储空间。您可以使用压缩算法来减小数据的存储空间,并使用存储过程和函数来优化数据的存储方式。此外,您还可以通过分区和分来分割数据,以便更好地管理和利用存储空间。 综上所述,通过使用独立空间,使用mysql-binuuid-rails插件,以及优化和压缩数据,可以提高MySQL的存储空间。这些方法的选择取决于您的具体需求和数据库结构。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [提高MySQL中InnoDBBLOB列的存储效率的教程](https://download.csdn.net/download/weixin_38692184/13693700)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [mysql-binuuid-rails:将UUID存储在MySQL二进制数据库列中。 节省存储空间并提高性能](https://download.csdn.net/download/weixin_42098892/15112536)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [基于java SSM+Mysql 的校园新闻系统](https://download.csdn.net/download/qq_35831906/88227122)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值