mysql – 在没有停机的情况下将数据类型从mediumint更改为int

我当前的表使用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运行时遭受延迟,然后进行受控切换.

上一篇:mysql – Keepalived vIP as Galera wsrep_cluster_address


下一篇:MySQL Replication在Ubuntu Lucid Lynx Server上无法正常运行