继续回答知识星球水友提问。
创新互联于2013年创立,是专业互联网技术服务公司,拥有项目成都做网站、成都网站设计、成都外贸网站建设网站策划,项目实施与项目整合能力。我们以让每一个梦想脱颖而出为使命,1280元金水做网站,已为上家服务,为金水各地企业和个人服务,联系电话:028-86922220
问题域:数据量大、并发量高场景,如何在流量低峰期,平滑实施表结构变更?
画外音,一般来说,是指增加表的属性,因为:
首先,一起看下有哪些常见方案。
(1) 方案一:在线修改表结构。
画外音:alter table add column
数据量大的情况下,锁表时间会较长,造成拒绝服务,一般不可行。
(2) 方案二:通过增加表的方式扩展属性,通过外键join来查询。
举个例子,对:
- t_user(uid, c1, c2, c3)
想要扩展属性,可以通过增加一个表实现:
- t_user_ex(uid, c4, c5, c6)
数据量大的情况下,join性能较差,一般不可行。
(3) 方案三,通过增加表的方式扩展,通过视图来屏蔽底层复杂性。
同上,视图效率较低,一般不使用视图。
画外音:至少58到家禁止使用视图。
(4) 方案四,揍产品经理,阻止她修改需求。...
(5) 方案五,提前预留一些reserved字段,加列可复用这些字段。
这个方案可行,但如果预留过多,会造成空间浪费。
(6) 方案六,pt-online-schema-change
对于MySQL而言,这是目前比较成熟的方案,被广大公司所使用。
画外音:我呆过的互联网公司,数据库均使用MySQL。
下面仍以用户表扩展为例,说下这个工具内部的原理与步骤。
假设:
- user(uid, name, passwd)
要扩展到:
- user(uid, name, passwd, age, sex)
第一步,先创建一个扩充字段后的新表:
- user_new(uid, name, passwd, age, sex)
画外音:就是被扩展后的表。
第二步,在原表user上创建三个触发器,对原表user进行的所有insert/delete/update操作,都会对新表user_new进行相同的操作;
第三步,分批将原表user中的数据insert到新表user_new,直至数据迁移完成;
第四步,删掉触发器,把原表移走(默认是drop掉);
第五步,把新表user_new重命名(rename)成原表user;
扩充字段完成,整个过程不需要锁表,可以持续对外提供服务。
操作过程中需要注意:
pt-online-schema-change是DBA必备的利器,比较成熟,在互联网公司使用广泛,要了解更详细的细节,亦可以Google一下。
任何脱离业务的架构设计都是耍流氓。
【本文为专栏作者“58沈剑”原创稿件,转载请联系原作者】
戳这里,看该作者更多好文
分享文章:几千万记录,数据库表结构如何平滑变更?
标题URL:http://www.gawzjz.com/qtweb2/news4/26004.html
网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联