系统设计:如何让系统容易扩展?

系统设计:如何让系统容易扩展?

一个高可扩展性指标,表示可以通过增加机器的方式来线性提高系统的处理能力,从而承担更高的流量或者并发数。

在单机系统中通过增加处理核心数来增加系统的并行处理能力,但是这个方法并不总生效,随着并行的任务增多,系统会因为争夺资源而达到性能上的拐点。系统性能会不升反降。

多台机器组成的机器系统也类似,在集群系统中,不同的分层也存在一些瓶颈。制约横向扩展能力。

举个例子,系统的流量是每秒1000次请求,对数据库请求也是 1000次/s ,单独如果流量增加10倍,系统可以扩容,正常提供服务,但是数据库就成了瓶颈。

再个例子,单机网络的带宽是50Mbps ,如果扩容到 30台机器,前端负载均衡带宽超过了1000Mbps 限制,那么也会成为瓶颈。

无状态的服务和组件更容易扩展,但是数据库这样的存储服务是有状态的,不易扩展。

数据库,缓存,依赖的第三方,负载均衡,交换机带宽,都是系统扩展性的一些因素。

系统扩展性设计思路

拆分是系统扩展性的最重要的思路,把庞大的系统进行拆分,有单一职责的模块,将复杂的问题简单化。

存储层扩展

  1. 按照业务拆分
    存储层扩展首先考虑的维度是业务维度。
    比如说有个社区系统,开始只有一个库,拆分之后,分成 用户库,关系库,内容库,评论库,点赞库等。

wangxiaoming CSDN认证博客专家 架构 Spring Boot Redis
博客是很好的总结和记录工具,如果有问题,来不及回复,关注微信公众号:程序员开发者社区,获取我的联系方式,向我提问,也可以给我发送邮件,联系 1275801617@qq.com
已标记关键词 清除标记
©️2020 CSDN 皮肤主题: Age of Ai 设计师:meimeiellie 返回首页
实付 19.89元
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值