mysql 有张 50G 的大单表,准备整理碎片(4G 多)

2019-11-30 17:12:14 +08:00
 caiem

mysql 是 5.7 版本,磁盘剩余空间为 40G. 如果执行 alter table xx engine=innodb,algorithm=inplace; 看一些文档说明是需要重建表操作,会占用一定的磁盘空间,那么是否会存在因为剩余空间不足操作失败的可能呢? 有没有不许重建表的方式整理碎片

2151 次点击
所在节点    数据库
2 条回复
nvkou
2019-12-01 02:15:56 +08:00
divide and conquer 可行的话上脚本可能写逻辑快一点。
065535
2019-12-03 16:21:27 +08:00
50G 的表,剩余空间为 40G。不管什么方式的碎片整理,基本流程是拷贝数据到新的存储上,随后释放原存储。如果碎片率大于 25%,[可能]会成功。为了保证 100%成功,建议清理其他表空间的历史数据来释放一些空间给这张单表做碎片整理。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/624615

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX