您的位置:首页 > 其它

用 pt-online-schema-change在线修改表结构的时候报超时

2015-08-28 22:18 246 查看
用工具pt-online-scheme-change执行添加字段是报错,提示超时,在凌晨反复执行几次后都是在创建触发器的时候超时退出了,表并不是很大大概1000w数据
执行语句:pt-online-schema-change --user=root --password='xxxxxx' --host=127.0.0.1 --port=3306 --charset=utf8 --alter="add flow_n int(11) default 1 COMMENT '数据流个数' " D=db_application,t=remote_diagnostic_report --execute;




网上查资料无果,执行show full processlist,看到后台进程,有个select语句(慢查询)在查询此表,查询还未完成,耗时很长。kill 掉这个进程后,执行pt语句修改表结构顺利完成.

总结:看书上说的,mysql5.6以后在线ddl 执行alter table表时,对该表的增删查改均不会锁表,而如果在这之前如果该表被访问,且查询未执行完毕,就开始执行alter table,是会超时的,或者说无法执行pt-osc 命令,所以最好选择在凌晨变更alter table,变更前查看此时是否有慢SQL 对表进行操作,以免改表时出现锁等待现象。 原则上单一个查询无论如何不会引起查询操作阻塞,但是这种情况就是会阻塞pt-osc操作。

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: