百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

活见鬼,明明删除了数据,空间却没减少

lipiwang 2024-11-02 13:39 11 浏览 0 评论

天天在用钱



迁移数据常用



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 压缩表时,需要留够一定的空间。

相关推荐

lushdns – 如何使用 Windows ipconfig /flushdns 命令刷新 DNS

您可能已经注意到,第一次访问网站后,下次访问时该网站的加载速度会更快。这是因为您的操作系统或浏览器(如果是GoogleChrome)会缓存您访问的任何网站的IP地址和DNS(域名系统)信息。...

Windows10电脑无法直接连接已保存无线网络逐步排查和解决方案

可能原因分析IP地址冲突:系统未能正确获取或释放IP地址,导致与路由器通信失败。DNS缓存/网络配置错误:旧的缓存或错误配置阻碍新连接。无线网卡驱动问题:驱动不兼容或存在故障。电源管理干扰:系统为省电...

删除电脑dns缓存(如何删除dns缓存)

用Windows+R快捷键打开「运行」,输入cmd,然后按Ctrl+Shift+Enter以管理员权限启动「命令提示符」。输入:ipconfig/flushdns回车...

电脑插网线无法上网的系统化解决方案

当电脑插上网线却无法访问网络时,可从物理连接、网络配置、驱动程序、系统设置等多维度排查问题。以下按优先级排序的解决方案,助你高效定位并解决故障。一、基础排查(解决80%常见问题)检查物理连接首先确...

《银与绯》国服海外畅玩解决方案(银绯什么意思)

对于海外玩家想要体验《银与绯》国服,使用SixFast游戏加速器是最佳选择。以下是详细操作指南:一、SixFast完整配置流程1.获取SixFast客户端-官网下载:访问sixfast.com选择对...

steam打不开/商店打不开的最新解决方法来了

steam打不开/商店打不开的最新解决方法来了Steam平台采用了统一的账户系统,玩家只需注册一个账户,就可以在平台上购买、下载和玩游戏。遇到Steam平台或商店打不开的烦恼?别担心,这里有几个简单实...

电脑恢复DNS最简单方法(如何恢复dns默认设置)

当电脑遇到DNS(域名系统)问题时,通常表现为无法访问某些网站或整个网络浏览变得缓慢而不稳定。DNS负责将人类可读的域名(如www.example.com)转换为机器可读的IP地址(如192.0.2....

WiFi越用越慢?几个简单操作让网络满血复活

关注硬件·聪明消费|欢迎关注钛师父动图:耳机震膜工作原理WiFi用了一段时间后便慢了?这恐怕不是幻觉,也不是运营商的猫腻,显然没有人会像苹果一样刻意降低你的网速逼你换套餐甚至换运营商。大多时候这样...

Win11快速开启DNS加密功能(国内可用)

今天我花了三个小时仔细研究了Windows的DNS加密(DoH)相关的内容,最终成功开启了国内可用的DNS加密功能,如果你还不知道什么是DoH并对原理感兴趣,可以参考这篇文章:https://zhua...

如何在 Windows 11 或 10 中使用 CMD 清除缓存

当你使用操作系统的时间变长,随着时间推移,缓存文件的积累可能会导致Windows11或10系统变慢,还会占用宝贵的存储空间,尤其是当您使用M.2固态硬盘的时候。因此,定期清除缓存文件或许...

绝地求生PUBG商店买不了东西Steam界面一直刷新加载的解决办法

在绝地求生(PUBG)的最新更新中,游戏引入了一系列新功能和优化,包括地图改进、武器平衡调整以及新的皮肤和物品。然而,随之而来的是一些玩家在尝试从游戏内商店购买这些新鲜内容时遇到了绝地求生PUBG商店...

Win11正式版网络错误访问提示0x800704cf的问题

有深度技术的用户在win11正式版系统电脑中出现网络错误提示0x800704cf错误代码,那么如何解决这个问题?接下来,深度官网小编为大家带来详细的解决方案,大家可以一起来看看。当Win11正式版...

网站维护进不去怎么办(网站在维护期间进不去)

当遇到网站无法访问并显示维护提示时,可能是临时维护,也可能存在其他故障。以下提供系统的排查步骤与解决方法,助你快速定位问题并解决。一、判断网站是否处于真实维护状态1.官方渠道信息核查公告查询:访问网...

网络适配器在设备管理器中消失的恢复方案

网络适配器(网卡)在设备管理器中突然消失,会导致设备无法正常联网,这通常由驱动异常、系统冲突或硬件故障引起。为帮助你高效解决问题,以下提供按操作复杂度由易到难排序的逐步恢复方案,请依次尝试。一、基础排...

【电脑蓝屏】常见的电脑问题解决方法

一、系统问题1.电脑开机慢/卡顿解决方法:关闭开机启动项:Ctrl+Shift+Esc→启动→禁用不必要的程序。清理磁盘:Win+S→搜索“磁盘清理”→勾选临时文件、...

取消回复欢迎 发表评论: