5

我有一个关于mysql的优化表的问题,我已经阅读了很多关于这个功能的文档,所有文档都说:它可以对InnoDB表进行碎片整理并重新组织表数据和关联索引数据的物理存储,以减少存储空间,但是没有人能告诉我优化表的原理并解决我的问题,我知道这些信息:

  1. 从 MySQL 5.6.17 开始,OPTIMIZE TABLE 对常规和分区 InnoDB 表使用在线 DDL
  2. ,从 MySQL 5.6.17 开始,由 OPTIMIZE TABLE 触发并在 ALTER TABLE 的掩护下执行的表重建... FORCE 就地完成(ALGORITHM =inplace)

我的问题:

  1. mysql的优化表真的rebuild(recreate) table吗?因为它就地完成(不是ALGORITHM=copy),ALGORITHM=inplace真的rebuild(recreate)表吗?

谢谢您的答复。

https://dev.mysql.com/doc/refman/5.6/en/innodb-online-ddl-operations.html

在此处输入图像描述

4

1 回答 1

7

演示:

我在 MySQL 5.6.37 上创建了一个表,并用大约 1GB 的随机数据填充了它。

mysql> select version();
+-----------------+
| version()       |
+-----------------+
| 5.6.37-82.2-log |
+-----------------+

mysql> show table status\G
*************************** 1. row ***************************
           Name: mytable
         Engine: InnoDB
        Version: 10
     Row_format: Compact
           Rows: 61914
 Avg_row_length: 20926
    Data_length: 1295613952
Max_data_length: 0
   Index_length: 1589248
      Data_free: 4194304
 Auto_increment: 131056
    Create_time: 2019-02-20 15:54:23
    Update_time: NULL
     Check_time: NULL
      Collation: utf8mb4_general_ci
       Checksum: NULL
 Create_options: 
        Comment: 

我可以观察我的数据目录中的文件并记下 inode 编号(最左边的数字)。

/usr/local/var/mysql/test ls -li
total 2590752
8625784850 -rw-rw----  1 bkarwin  admin          67 Feb 20 07:54 db.opt
8625784853 -rw-rw----  1 bkarwin  admin        8580 Feb 20 07:54 mytable.frm
8625784854 -rw-rw----  1 bkarwin  admin  1321205760 Feb 20 07:56 mytable.ibd

我运行优化表。

mysql> optimize table mytable;

在它运行时,我通过再次列出 datadir 中的文件来检查进度。我看到它创建了一个新的临时文件,并用数据副本填充它。

请注意临时文件的 inode 编号。

/usr/local/var/mysql/test ls -li
total 4395064
8625785082 -rw-rw----  1 bkarwin  admin        8580 Feb 20 07:57 #sql-337_16.frm
8625785083 -rw-rw----  1 bkarwin  admin   914358272 Feb 20 07:57 #sql-ib2021-3689447301.ibd
8625784850 -rw-rw----  1 bkarwin  admin          67 Feb 20 07:54 db.opt
8625784853 -rw-rw----  1 bkarwin  admin        8580 Feb 20 07:54 mytable.frm
8625784854 -rw-rw----  1 bkarwin  admin  1321205760 Feb 20 07:56 mytable.ibd

最后我的优化表完成了。花了将近2分钟。如果它不是在做一个真正的表格副本,为什么要花这么长时间?

+--------------+----------+----------+-------------------------------------------------------------------+
| Table        | Op       | Msg_type | Msg_text                                                          |
+--------------+----------+----------+-------------------------------------------------------------------+
| test.mytable | optimize | note     | Table does not support optimize, doing recreate + analyze instead |
| test.mytable | optimize | status   | OK                                                                |
+--------------+----------+----------+-------------------------------------------------------------------+
2 rows in set (1 min 5.52 sec)

再次查看datadir,我看到临时文件已被重命名为新表空间,而旧文件已被删除。新文件具有临时文件的 inode 编号,表明它是副本。

/usr/local/var/mysql/test ls -li
total 2557984
8625784850 -rw-rw----  1 bkarwin  admin          67 Feb 20 07:54 db.opt
8625785082 -rw-rw----  1 bkarwin  admin        8580 Feb 20 07:57 mytable.frm
8625785083 -rw-rw----  1 bkarwin  admin  1304428544 Feb 20 07:58 mytable.ibd
于 2019-02-20T16:04:23.017 回答