MySQL -- 空间回收

栏目: 数据库 · 发布时间: 6年前

内容简介:空洞:

空洞: 可以被复用但没有被使用的空间 ,经过大量 增删改 的表,都会存在空洞

删除

MySQL -- 空间回收

  1. 如果删掉 R4 ,InnoDB只会将 R4 标记为删除 ,如果再插入 300~600 的记录时,可能会 复用 这个位置,但磁盘文件不会缩小
    • 记录的复用 ,仅限于 符合范围 条件的数据
  2. 如果删除了 一个数据页上的所有记录 ,那么 整个数据页 都可以被 复用
    • 整个页 从B+树里摘除后,可以被复用到 任何位置
    • 如果将 page A 上的所有记录删除后, page A 会被 标记为可复用
      • 当插入ID=50的记录时,需要 申请新页page A 可以被复用
  3. 如果 相邻 的两个数据页 利用率 都很小
    • 系统会把这两个数据页上的数据 合并 到其中一个页上,另一个数据页就会被标记为 可复用
  4. 如果通过 DELETE 命令 删除整个表 ,那么 所有的数据页 都会被 标记为可复用 ,但磁盘上的文件同样不会变小
  5. TRUNCATE = DROP + CREATE

插入

MySQL -- 空间回收

  1. 如果数据是 随机插入 的,就有可能造成 索引的数据页分裂
  2. page A 已满,如果再插入ID=550的数据,就必须申请一个新的页面 page B 来保存数据,导致 页分裂 ,留下了空洞

更新

更新 索引 上的值,等同于 先逻辑删除旧值后再插入新值 ,同样也会造成 空洞

重建表

逻辑过程

  1. 新建一个与表A 结构相同 的表B
  2. 按照 主键递增 的顺序,把表A中的数据一行一行读出,然后再插入表B
    • 表B的主键索引更 紧凑 ,数据页的 利用率 也更高
  3. 表B作为 临时表 ,数据从表A导入到表B,然后用表B替换A

重建命令

ALTER TABLE A ENGINE=InnoDB;

ALTER TABLE 默认会 提交前面的事务

Before MySQL 5.5

MySQL -- 空间回收

  1. 与上述的逻辑过程类似,MySQL 自动完成 转存数据,交换表名和删除旧表等操作
  2. 时间消耗最多的是往 临时表Server层 )插入数据的过程,在这个过程中,如果 新数据 要写入表A,就会造成 数据丢失
  3. 因此整个DDL过程中,表A是不能执行DML的,即不是 Online
  4. MySQL 5.6引入 Online DDL

Since MySQL 5.6

MySQL -- 空间回收

  1. 建立一个 临时文件InnoDB内部 ),扫描表A主键的所有数据页
  2. 用数据页中表A的记录生成B+树,存储到临时文件
  3. state 2( 日志 ):生成临时文件的过程中,将所有对A的 操作 记录在一个 日志文件row log )中
  4. state 3( 重放 ):临时文件生成后,将日志文件的操作 应用到临时文件 ,得到一个 逻辑数据 上与表A相同的数据文件
  5. 用最新的临时文件替换表A的数据文件

MDL锁

  1. ALTER 语句在 启动 时需要获取 MDL写锁 ,但会在 真正拷贝数据之前退化为MDL读锁
    • MDL读锁 不会阻塞 其他线程对这个表的 DML ,同时又能 阻塞 其他线程对这个表的 DDL
  2. 对一个大表来说, Online DDL 最耗时的过程是 拷贝数据到临时表 的过程,期间是可以接受DML
    • 相对于整个DDL过程来说, 锁的时间非常短 ,对 业务 来说,可以认为是 Online

性能消耗

  1. 重建表会 扫描原表数据构建临时文件(或临时表)
  2. 对于大表来说,重建表会 非常消耗IO和CPU资源
  3. 推荐工具: gh-ost

Online + Inplace

  1. tmp_table 是一个 临时表 ,在 Server 层创建的
  2. tmp_file临时文件 ,在 InnoDB 内部创建的, 整个DDL过程都在InnoDB内部完成
    • 对于 Server 层来说,并没有把数据挪动到 临时表 ,是个原地操作( Inplace
  3. DDL过程如果是Online的,那一定是Inplace的,反之不成立
    • ALTER TABLE t ADD FULLTEXT(field_name);Inplace 的,但会阻塞DML( 非Online
ALTER TABLE A ENGINE=InnoDB;
等同于
mysql> ALTER TABLE t ENGINE=InnoDB, ALGORITHM=INPLACE;
Query OK, 0 rows affected (0.68 sec)
Records: 0  Duplicates: 0  Warnings: 0

Inplace 对应的是 Copy ,强制拷贝表到 Server

mysql> ALTER TABLE t ENGINE=InnoDB, ALGORITHM=COPY;
Query OK, 100000 rows affected (1.46 sec)
Records: 100000  Duplicates: 0  Warnings: 0

ALTER + ANALYZE + OPTIMIZE

  1. ALTER TABLE t ENGINE=InnoDB重建表
  2. ANALYZE TABLE t :触发 表索引信息的重新采样统计
  3. OPTIMIZE TABLE tALTER + ANALYZE

参考资料

《MySQL实战45讲》

转载请注明出处:http://zhongmingmao.me/2019/02/01/mysql-reclaim-space/

访问原文「MySQL -- 空间回收」获取最佳阅读体验并参与讨论


以上所述就是小编给大家介绍的《MySQL -- 空间回收》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Computers and Intractability

Computers and Intractability

M R Garey、D S Johnson / W. H. Freeman / 1979-4-26 / GBP 53.99

This book's introduction features a humorous story of a man with a line of people behind him, who explains to his boss, "I can't find an efficient algorithm, but neither can all these famous people." ......一起来看看 《Computers and Intractability》 这本书的介绍吧!

html转js在线工具
html转js在线工具

html转js在线工具

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具

HSV CMYK 转换工具
HSV CMYK 转换工具

HSV CMYK互换工具