当前位置:首页 > > 架构师社区
[导读]‍mysqldump是Mysql自带的逻辑备份工具,其备份原理是通过协议连接到Mysql数据库,将需要备份的数据查询出来转换成对应的insert语句。当需要还原这些数据时,只要执行这些insert语句,即可将对应的数据还原。



明明删除了数据,为何空间却没减少?

明明删除了数据,为何空间却没减少?

明明删除了数据,为何空间却没减少?

明明删除了数据,为何空间却没减少?

明明删除了数据,为何空间却没减少?


迁移数据常用


明明删除了数据,为何空间却没减少?


1、导出文件 - mysqldump 命令


mysqldump 是 Mysql 自带的逻辑备份工具。其备份原理是通过协议连接到 Mysql 数据库,将需要备份的数据查询出来转换成对应的 insert 语句。当需要还原这些数据时,只要执行这些 insert 语句,即可将对应的数据还原。



常用命令:


  • 导出所有数据库

mysqldump -uroot -p123456 --all-databases  >/tmp/all.sql
  • 导出指定数据库

mysqldump -uroot -p123456 --databases db >/tmp/db.sql
  • 导出指定表

mysqldump -uroot -p123456 --databases  db  --tables a >/tmp/a.sql
  • 根据条件导出数据

mysqldump -uroot -p123456 --databases db --tables a --where='id=1' >/tmp/a.sql
  • 只导出表结构

mysqldump -uroot -p123456 --no-data --databases db >/tmp/db.sql


2、导入文件 - source 命令


source 命令可以将导出的 sql 文件导入进指定数据库。


操作步骤:

  • use 数据库;

  • soucre 已导出的 sql 文件。



明明删除了数据,为何空间却没减少?


迁移思路


1. 数据库A历史数据迁移到 hdfs(一种分布式文件系统)上进行归档;


2. 删除数据库A已归档的表,使用 drop 命令;


3. 数据库A上新建表,用于数据库B迁移;


4. 数据库B中除未完成单外都迁移至数据库A;


5. 脚本进行删除数据库B上已迁移数据。


明明删除了数据,为何空间却没减少?


明明删除了数据,为何空间却没减少?

明明删除了数据,为何空间却没减少?


阿丁开讲


1、参数介绍


在 Innodb 存储引擎中,innodb_file_per_table 参数是用来控制表数据的存储方式的。


当参数为 OFF 的时候,所有数据都存放于默认路径下名为 ibdata* 的共享表空间里,即将数据库所有的表数据及索引文件存放到一个文件中。在删除数据表的时候,ibdata* 文件不会自动收缩。


当参数为 ON 的时候,每一个表都将存储在一个以 .ibd 为后缀的文件中。这样每个表都有了自己独立的表空间,通过 drop table 命令就可以将表空间进行回收。


从 Mysql 5.6.6 版本开始,innodb_file_per_table 默认为 ON 状态


2、参数设置


通过 show variables like '%per_table%' 命令,可以查看 innodb_file_per_table 参数的当前状态:


明明删除了数据,为何空间却没减少?


如果想修改参数的状态,可通过 SET GLOBAL 动态地修改为 ON 或 OFF,也可以在 my.cnf 中做永久性修改。需要注意的是,在 my.cnf 中修改后生效的话需要重启 mysqld 服务。


疑问:如果之前参数为 OFF 状态,设置为 ON 状态后,表空间如何分配?


答案是仅对后续操作生效。


什么意思呢?修改前的数据还维持原状,也就是说之前的数据继续存放于 ibdata* 文件中,修改后的使用独立表空间。


所以建议在开始就将该参数设置为 ON 状态。


明明删除了数据,为何空间却没减少?

第二天



明明删除了数据,为何空间却没减少?

明明删除了数据,为何空间却没减少?

明明删除了数据,为何空间却没减少?


阿丁二次开讲


在这之前要先介绍下 Innodb 存储数据所用的 B+ 树结构,画个图你理解下:

明明删除了数据,为何空间却没减少?

在图中,P 代表一页数据,R 代表一行数据。


假设我们要删掉 R2 这条记录,InnoDB 引擎只会将其标记为删除状态,并不会真正把这行数据所占的空间释放掉,也就是说这个坑位还留着。如果后续所插入的数据在 R1 与 R3 之间的话,这个空间是可以被使用上的。


假设我们恰好删除了 R1、R2、R3 这三条记录,也就是说 P1 这一页的数据都被删掉了,那么 P1 所在的空间都会被标记为可复用。如果插入的数据需要使用新页的话,P1 的坑位就可以被利用起来了。


那么你可能会问了,我插入的数据恰好巧妙的避开了这些位置呢。那我还能说啥,骚呗。这样会造成很多空间被浪费,如果删除大量的数据的话,被浪费的空间也会是巨大的。


明明删除了数据,为何空间却没减少?

optimize table 的本质是 ALTER TABLE xxx ENGINE = InnoDB;


在5.5版本之前,重建表的过程是这样的:


明明删除了数据,为何空间却没减少?

明明删除了数据,为何空间却没减少?


明明删除了数据,为何空间却没减少?

明明删除了数据,为何空间却没减少?

明明删除了数据,为何空间却没减少?

明明删除了数据,为何空间却没减少?

然后用临时文件替换旧表,这样便实现了表的重建。

明明删除了数据,为何空间却没减少?


注意


1、控制迁移速度,防止主从延迟导致线上故障;


2、创建大表时,使用下面的建表语句可节省 50% 左右的空间:

ROW_FORMAT=COMPRESSED KEY_BLOCK_SIZE=8


3、使用 optimize table 压缩表时,需要留够一定的空间。




END -

明明删除了数据,为何空间却没减少?

特别推荐一个分享架构+算法的优质内容,还没关注的小伙伴,可以长按关注一下:

明明删除了数据,为何空间却没减少?

明明删除了数据,为何空间却没减少?

明明删除了数据,为何空间却没减少?

长按订阅更多精彩▼

明明删除了数据,为何空间却没减少?

如有收获,点个在看,诚挚感谢

免责声明:本文内容由21ic获得授权后发布,版权归原作者所有,本平台仅提供信息存储服务。文章仅代表作者个人观点,不代表本平台立场,如有问题,请联系我们,谢谢!

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

LED驱动电源的输入包括高压工频交流(即市电)、低压直流、高压直流、低压高频交流(如电子变压器的输出)等。

关键字: 驱动电源

在工业自动化蓬勃发展的当下,工业电机作为核心动力设备,其驱动电源的性能直接关系到整个系统的稳定性和可靠性。其中,反电动势抑制与过流保护是驱动电源设计中至关重要的两个环节,集成化方案的设计成为提升电机驱动性能的关键。

关键字: 工业电机 驱动电源

LED 驱动电源作为 LED 照明系统的 “心脏”,其稳定性直接决定了整个照明设备的使用寿命。然而,在实际应用中,LED 驱动电源易损坏的问题却十分常见,不仅增加了维护成本,还影响了用户体验。要解决这一问题,需从设计、生...

关键字: 驱动电源 照明系统 散热

根据LED驱动电源的公式,电感内电流波动大小和电感值成反比,输出纹波和输出电容值成反比。所以加大电感值和输出电容值可以减小纹波。

关键字: LED 设计 驱动电源

电动汽车(EV)作为新能源汽车的重要代表,正逐渐成为全球汽车产业的重要发展方向。电动汽车的核心技术之一是电机驱动控制系统,而绝缘栅双极型晶体管(IGBT)作为电机驱动系统中的关键元件,其性能直接影响到电动汽车的动力性能和...

关键字: 电动汽车 新能源 驱动电源

在现代城市建设中,街道及停车场照明作为基础设施的重要组成部分,其质量和效率直接关系到城市的公共安全、居民生活质量和能源利用效率。随着科技的进步,高亮度白光发光二极管(LED)因其独特的优势逐渐取代传统光源,成为大功率区域...

关键字: 发光二极管 驱动电源 LED

LED通用照明设计工程师会遇到许多挑战,如功率密度、功率因数校正(PFC)、空间受限和可靠性等。

关键字: LED 驱动电源 功率因数校正

在LED照明技术日益普及的今天,LED驱动电源的电磁干扰(EMI)问题成为了一个不可忽视的挑战。电磁干扰不仅会影响LED灯具的正常工作,还可能对周围电子设备造成不利影响,甚至引发系统故障。因此,采取有效的硬件措施来解决L...

关键字: LED照明技术 电磁干扰 驱动电源

开关电源具有效率高的特性,而且开关电源的变压器体积比串联稳压型电源的要小得多,电源电路比较整洁,整机重量也有所下降,所以,现在的LED驱动电源

关键字: LED 驱动电源 开关电源

LED驱动电源是把电源供应转换为特定的电压电流以驱动LED发光的电压转换器,通常情况下:LED驱动电源的输入包括高压工频交流(即市电)、低压直流、高压直流、低压高频交流(如电子变压器的输出)等。

关键字: LED 隧道灯 驱动电源
关闭