V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
caiem
V2EX  ›  数据库

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

  •  
  •   caiem · 2019-11-30 17:12:14 +08:00 · 2234 次点击
    这是一个创建于 1823 天前的主题,其中的信息可能已经有所发展或是发生改变。

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

    2 条回复    2019-12-03 16:21:27 +08:00
    nvkou
        1
    nvkou  
       2019-12-01 02:15:56 +08:00 via Android
    divide and conquer 可行的话上脚本可能写逻辑快一点。
    065535
        2
    065535  
       2019-12-03 16:21:27 +08:00
    50G 的表,剩余空间为 40G。不管什么方式的碎片整理,基本流程是拷贝数据到新的存储上,随后释放原存储。如果碎片率大于 25%,[可能]会成功。为了保证 100%成功,建议清理其他表空间的历史数据来释放一些空间给这张单表做碎片整理。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   6043 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 29ms · UTC 02:28 · PVG 10:28 · LAX 18:28 · JFK 21:28
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.