如何让笨重的架构变灵巧?
随着业务的复杂性增大、系统吞吐量增长,所有功能统一部署难度加大,各个功能模块相互影响使系统变的笨重且脆弱,因此需要对业务进行拆分、对系统进行解耦、对系统内部架构升级,以此来提升系统容量及健壮性。 接下来主要分两部分介绍:系统拆分结构演变 一、系统拆分 系统拆分从资源角度分为应用拆分和数据库拆分,而从采用的先后顺序则可分为: 水平扩展;垂直拆分;业务拆分;水平拆分。 图1 系统分解原则 1水平扩展 水平扩展是最初始的解决的手段,也是系统遇到瓶颈的首选方案,主要从以下两个方面扩展: 应用加实例,搞集群,把系统吞吐量扩上去;数据库利用主从进行读写分离,数据库其实是系统最应该保护的资源。 2垂直拆分 垂直拆分才是真正开始拆分系统,主要是从业务功能角度拆分。如拆出用户系统、商品系统、交易系统等。 为了解决拆分后各个子系统之间相互依赖调用的问题,这时会引入服务调用治理。虽然系统复杂度有所加大,但系统基本解耦,稳定性相对提高,做好降级就能避免因其它系统功能异常导致系统崩溃问题。 业务对应的库也会按照对应的业务拆分出用户库、商品库、交易库等。 3业务拆分 业务拆分主要是针对应用层面按功能特点拆分,如交...


