标签:mysql ddl
目前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
标签:mysql ddl
原文地址:http://birdinroom.blog.51cto.com/7740375/1690390