我当前的表使用MEDIUMINT作为ID列’主键自动增量’.当前表记录很快将达到mediumint的最大值8388607.在这种情况下,我需要将类型更改为int或将其更改为unsigned而不会出现任何停机.
我的设置是Amazon RDS上的主从MySQL 5.6.我有一个主人和4个奴隶.
>我试图在slave上将列类型更改为int但它会破坏复制.
>记录正在发生变化,因此无法将表复制到另一个表.
>我不能在Amazon RDS上使用pt-table-sync来同步另一个表,然后在新表上进行更改.
有没有办法在不锁定表的情况下更改为int?
更新:我不确定该属性是已签名还是未签名.我无法找到它在哪里签名.我从表中运行show列,结果如下:
+----------------+--------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+----------------+--------------+------+-----+---------+----------------+
| id | mediumint(8) | NO | PRI | NULL | auto_increment |
解决方法:
虽然Rolando有我的投票,因为他的情况正确,我想回答你关于percona工具包的原始问题(对于你以及其他人):
pt-table-sync不是你想要的.想想pt-online-schema-change
.虽然有一些硬角,但它适用于RDS,具有正确的配置或对脚本的最小更改. pt-table-sync也将是fix the issues with rds in the next release.还有其他替代方案可用于在线架构更改,oak-toolkit和Facebook.
作为替代方案,您需要一个备用从站,它可以在ALTER运行时遭受延迟,然后进行受控切换.