作者 陈彩华
文章转载交流请联系 caison@aliyun.com
![](https://img.haomeiwen.com/i5618238/45eb7e199b4e2208.jpg)
最近学习了阿里资深技术专家李运华的架构设计关于分库分表的教程,颇有收获,总结一下。
本文主要介绍高性能数据库集群分库分表相关理论,基本架构,涉及的复杂度问题以及常见解决方案。
分库分表概述
![](https://img.haomeiwen.com/i5618238/3255d9e9ddc2ec2b.png)
读写分离分散数据库读写操作压力,分库分表分散存储压力
适用场景
![](https://img.haomeiwen.com/i5618238/65d8b7e266b9d0dd.png)
类似读写分离,分库分表也是确定没有其他优化空间之后才采取的优化方案。那如果业务真的发展很快岂不是很快要进行分库分表了?那为何不一开始就设计好呢?
按照架构设计的“三原则”(简单原则,合适原则,演化原则),简单分析一下:
首先,这里的“如果”事实上发生的概率比较低,做10个业务有一个业务能活下去就很不错了,更何况快速发展,和中彩票的概率差不多。如果我们每个业务上来就按照淘宝、微信的规模去做架构设计,不但会累死自己,还会害死业务。
其次,如果业务真的发展很快,后面进行分库分表也不迟。因为业务发展好,相应的资源投入就会加大,可以投入更多的人和更多的钱,那业务分库带来的代码和业务复杂问题就可以通过加人来解决,成本问题也可以通过增加资金来解决。
业务分库
![](https://img.haomeiwen.com/i5618238/36a209c1dea789a7.png)
![](https://img.haomeiwen.com/i5618238/ee84446b35676125.jpg)
业务分表
业务分表概述
![](https://img.haomeiwen.com/i5618238/09eba8d05a18f9aa.png)
![](https://img.haomeiwen.com/i5618238/a120249dcd6a9343.jpg)
带来的问题
垂直分表
增加表操作的次数
水平分表
- 路由问题
![](https://img.haomeiwen.com/i5618238/fa3e86227db9877d.png)
- 数据库操作问题
![](https://img.haomeiwen.com/i5618238/02241d45a2ffbb04.png)
实现方法
![](https://img.haomeiwen.com/i5618238/4f3534f5bd04994c.png)
类似读写分离,具体实现也是“程序代码封装”和“中间件封装”,但具体实现复杂一些,因为还有要判断SQL中具体操作的表,具体操作(例如count、order by、group by等),根据具体操作做不同的处理。
参考
网友评论