Bootstrap

Online DDL (Data Definition Language)

Online DDL (Data Definition Language) 是MySQL中的一个功能,允许在修改表结构(如添加、删除或修改列)的同时,允许对表进行并发读写操作。在传统的DDL操作中,对表结构的修改会导致整个表被锁定,从而阻止其他事务对该表进行读写操作,这可能导致长时间的锁定和性能问题。

Online DDL的引入解决了这个问题,它允许在修改表结构的同时,保持对表的并发访问。这意味着在进行表结构更改时,其他事务仍然可以查询表、插入数据、更新数据和删除数据。

MySQL从5.6版本开始引入了Online DDL的部分功能,而在8.0版本中对Online DDL进行了进一步的优化。

Online DDL的工作机制如下:

  1. 当你执行一个DDL操作时(如ALTER TABLE),MySQL会首先获取一个MDL(元数据锁)写锁。
  2. 在获取到写锁后,MySQL会进行初始化操作,这可能包括创建一个新的临时表或复制原始表的数据。
  3. 之后,MySQL会将MDL写锁降级为MDL读锁,并开始实际的表结构更改操作。在此过程中,其他事务可以持有读锁来访问原始表。
  4. 在表结构更改完成后,MySQL会再次升级MDL锁为写锁,完成最后的操作并释放锁。

使用Online DDL可以大大减少锁定时间,提高并发性能,尤其是在大表上执行结构更改时。但是,它并不总是适用于所有场景,某些复杂的DDL操作可能仍然需要较长时间并影响性能。因此,在使用Online DDL时,建议先在测试环境中验证其效果,并确保备份数据以防万一。

悦读

道可道,非常道;名可名,非常名。 无名,天地之始,有名,万物之母。 故常无欲,以观其妙,常有欲,以观其徼。 此两者,同出而异名,同谓之玄,玄之又玄,众妙之门。

;