用 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操作。
执行语句: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操作。
相关文章推荐
- 第六讲 Block块语法及Block与数组的排序,ios字面量的使用(源代码上传)
- ViewPager实现无限轮播图
- Android Fragment 真正的完全解析(下)
- 亿级用户下的新浪微博平台架构
- 集群服务器session共享
- Single Number
- 非参数密度估计(直方图与核密度估计)
- android---gettag()与settag()的妙用
- Linux的timerfd分析
- 字符集和字符编码(Charset & Encoding)
- 树莓派deian的linux常用命令
- 深入浅出CChart 每日一课——快乐高四第十一课 不离不弃,利用CChartWnd实现多区域绘图
- ehcache memcache redis 三大缓存男高音
- 单表60亿记录等大数据场景的MySQL优化和运维之道
- HTTP文件传输
- SSH之旅(一)——框架简介
- Linux 基础命令
- oracle 导入execl
- easyui-editing datagrid 批量保存数据 二
- win8 X64上安装32位Oracle Instant Client(即时客户端) 安装与配置