码迷,mamicode.com
首页 > 其他好文 > 详细

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

时间:2015-08-28 23:04:47      阅读:175      评论:0      收藏:0      [点我收藏+]

标签:

用工具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操作。
 
 
 
 
技术分享

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

标签:

原文地址:http://www.cnblogs.com/mysqlplus/p/4768035.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!