CSDN博主:【java_wxid】
CSDN博主:点击【Java廖志伟】
CSDN社区:点击【幕后大佬】
码云:点击【互联网Java工程师知识扫盲】
随笔 - 882,  文章 - 0,  评论 - 1,  阅读 - 51602

1.背景

在实际应用中,我们经常会遇到需要修改大表结构的情况,比如增加或删除字段、修改字段类型、添加或删除索引等。但是,这些修改操作都是要对线上数据库进行的,如果处理不当,就容易导致数据丢失、性能下降、系统崩溃等问题,给业务带来不可挽回的损失。因此,本文总结了MySQL线上修改大表结构的风险及对应的解决方案,希望能够帮助读者更好地应对这类问题。

2.风险

2.1 数据库锁定

在MySQL中,对表进行修改操作时,会自动为这张表加锁,防止其他操作干扰。如果要修改大表,需要执行长时间的锁定操作,这就会导致其他用户无法访问该表,甚至会导致整个系统崩溃。因此,在进行大表结构修改操作前,需要考虑相关的锁定问题。

解决方案:

a. 在非高峰期进行修改操作,减少影响;
b. 使用在线DDL工具,如pt-online-schema-change,避免锁表问题;
c.

posted on   我是廖志伟  阅读(156)  评论(0编辑  收藏  举报  
相关博文:
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
历史上的今天:
2022-07-24 模板引擎:第一章:FreeMarker
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

南北踏尘
点击右上角即可分享
微信分享提示