分区分表分库

本文详细介绍了数据库扩展策略,包括分区、分表和分库的概念和应用场景。首先讨论了单机数据库常见的瓶颈,然后分别阐述了分区如何提升查询效率,分表如何提高并发能力和I/O性能,以及分库解决的存储空间和查询压力问题。文中提到了各种分区模式,如Range、Hash、Key和List,并探讨了垂直分表和水平分表的策略。最后,文章指出了分库面临的问题,如分布式事务和支持JOIN操作的挑战,以及可能的解决方案。
摘要由CSDN通过智能技术生成

优先考虑分区。当分区不能满足需求时,开始考虑分表,合理的分表对效率的提升会优于分区。

分布式集群结构设计:

框架采用三层设计:最上层是Cluster,一个Cluster相当于我们常规的一个数据库;一个Cluster当中可以包含一到多个Partition,也就是分区;而一个Partition中可以包含一到多个Shard,也就是分片。

所以一个就形成了一个树状结构,通过Cluster->Partion->Shard就构成了整个数据库集群。但是对于开发人员来说,实际上并不知道这个内部结构,他只是连接上了一个JDBC数据源,然后做它应该做的事情就可以了。

Cluster

以完整的形态对外提供服务,它封装了Cluster当中所有Partition及其Shard的访问。把它打开是一个数据库集群,对于使用者来说是一个完整的数据库。

属性名

类型

说明

id

String

集群标识

userName

String

连接集群时的用户名

Password

String

连接集群时的密码

dataSources

List<DataSourceConfig>

集群中需要访问的数据源列表

partitions

List<Partition>;

集群中包含的分区列表

Partition

分区,分区有两种模式,一种是主从模式,用于做读写分离另外一种模式是分片模式,也就是说把一个表中的数据分解到多个表中。一个分区只能是其中的一种模式。但是一个Cluster可以包含多个分区,不同的分区可以是不同的模式。

属性名

类型

说明

id

String

分区标识

mode

int

分区类型,可以是主从,也可以是分表

Password

String

连接集群时

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

KunQian_smile

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值