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

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,replication,alter-table,datatypes
来源: https://codeday.me/bug/20190807/1605187.html