目前InnoDB引擎是通过以下步骤来进行DDL的:

1 按照原始表(original_table)的表结构和DDL语句,新建一个不可见的临时表(tmp_table)

2 在原表上加write lock,阻塞所有更新操作(insert、delete、update等)

3 执行insert into tmp_table select * from original_table

4 rename original_table和tmp_table,最后drop original_table

5 释放 write lock。

我们可以看见在InnoDB执行DDL的时候,原表是只能读不能写的。为此 perconal 推出一个工具 pt-online-schema-change ,其特点是修改过程中不会造成读写阻塞。

工作原理:

如果表有外键,除非使用 –alter-foreign-keys-method 指定特定的值,否则工具不予执行。

1 创建一个和你要执行 alter 操作的表一样的空表结构。

2 执行表结构修改,然后从原表中的数据到copy到 表结构修改后的表,

3 在原表上创建触发器将 copy 数据的过程中,在原表的更新操作 更新到新表.

注意:如果表中已经定义了触发器这个工具就不能工作了。

4 copy 完成以后,用rename table 新表代替原表,默认删除原表。


pt-online-schema-change -uroot -h172.17.10.13 -p'test!' --alter='add key user_email(email)' --execute D=ggxk_account,t=ggxk_user

pt-online-schema-change -uroot -h172.17.10.13 -p'test!' --alter='drop key user_email ' --execute D=ggxk_account,t=ggxk_user

pt-online-schema-change -uroot -h172.17.10.13 -p'test!' --alter='add column lhb int ' --execute D=ggxk_account,t=ggxk_user

pt-online-schema-change -uroot -h172.17.10.13 -p'test!' --alter='drop column lhb ' --execute D=ggxk_account,t=ggxk_user