ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

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

2019-08-07 01:15:45  阅读:361  来源: 互联网

标签:mysql replication alter-table datatypes


我当前的表使用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

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有