几万万记录,数据库表布局怎样滑腻改观?
继承答复常识星球水友提问。 题目域:数据量大、并发量高场景,如安在流量低峰期,滑腻实验表布局改观? 画外音,一样平常来说,是指增进表的属性,由于:
起首,一路看下有哪些常见方案。 (1) 方案一:在线修改表布局。 画外音:alter table add column 数据量大的环境下,锁表时刻会较长,造成拒绝处事,一样平常不行行。 (2) 方案二:通过增进表的方法扩展属性,通过外键join来查询。 举个例子,对:
想要扩展属性,可以通过增进一个表实现:
数据量大的环境下,join机能较差,一样平常不行行。 (3) 方案三,通过增进表的方法扩展,通过视图来屏障底层伟大性。 同上,视图服从较低,一样平常不行使视图。 画外音:至少58抵家榨取行使视图。 (4) 方案四,揍产物司理,阻止她修改需求。... (5) 方案五,提前预留一些reserved字段,加列可复用这些字段。 这个方案可行,但假如预留过多,会造成空间挥霍。 (6) 方案六,pt-online-schema-change 对付MySQL而言,这是今朝较量成熟的方案,被宽大公司所行使。 画外音:我呆过的互联网公司,数据库均行使MySQL。 下面仍以用户表扩展为例,说下这个器材内部的道理与步调。 假设:
要扩展到:
第一步,先建设一个扩充字段后的新表:
画外音:就是被扩展后的表。 第二步,在原表user上建设三个触发器,对原表user举办的全部insert/delete/update操纵,城市对新表user_new举办沟通的操纵; 第三步,分批将原表user中的数据insert到新表user_new,直至数据迁徙完成; 第四步,删掉触发器,把原表移走(默认是drop掉); 第五步,把新表user_new重定名(rename)成原表user; 扩充字段完成,整个进程不必要锁表,可以一连对外提供处事。 操纵进程中必要留意:
pt-online-schema-change是DBA必备的利器,较量成熟,在互联网公司行使普及,要相识更具体的细节,亦可以Google一下。 任何离开营业的架构计划都是耍混混。 【本文为51CTO专栏作者“58沈剑”原创稿件,转载请接洽原作者】 戳这里,看该作者更多好文 【编辑保举】
点赞 0 (编辑:河北网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |