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

时间:2021-12-03 18:38:46
用工具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;  用 pt-online-schema-change在线修改表结构的时候报超时用 pt-online-schema-change在线修改表结构的时候报超时
 
网上查资料无果,执行show full processlist,看到后台进程,有个select语句(慢查询)在查询此表,查询还未完成,耗时很长。kill 掉这个进程后,执行pt语句修改表结构顺利完成. 
 
总结:看书上说的,mysql5.6以后在线ddl 执行alter table表时,对该表的增删查改均不会锁表,而如果在这之前如果该表被访问,且查询未执行完毕,就开始执行alter table,是会超时的,或者说无法执行pt-osc 命令,所以最好选择在凌晨变更alter table,变更前查看此时是否有慢SQL 对表进行操作,以免改表时出现锁等待现象。 原则上单一个查询无论如何不会引起查询操作阻塞,但是这种情况就是会阻塞pt-osc操作。
 
 
 
 
用 pt-online-schema-change在线修改表结构的时候报超时