可扩展的基本思想:都可以总结为一个字:拆!就是将原本大一统的系统拆分成多个规模小的部分,扩展时只修改其中一部分即可,无须整个系统到处都改,通过这种方式来减少改动范围,降低改动风险
按照不同的思路来拆分软件系统,就会得到不同的架构。常见的拆分思路有如下三种:
面向流程拆分:将整个业务流程拆分为几个阶段,每个阶段作为一部分。
比如:信息管理学系统的 展示层 → 业务层 → 数据层 → 存储层
面向服务拆分:将系统提供的服务拆分,每个服务作为一部分。
比如:将系统拆分为注册、登录、信息管理、安全设置等服务,
面向功能拆分:将系统提供的功能拆分,每个功能作为一部分
比如:每个服务都可以拆分为更多细粒度的功能:比如注册服务、登陆服务、信息管理服务、安全设置服务
从范围上来看,从大到小依次为:流程>服务>功能。不同的拆分方式,本质上决定了系统的扩展方式,可以保证证即使程序员出错,出错的范围也不会太广
1.面向流程拆分:扩展时大部分情况只需要修改某一层,少部分情况可能修改关联的两层,不会出现所有层都同时要修改。例如学生信息管理系统,如果我们将存储层从MySQL扩展为同时支 持MySQL和Oracle,那么只需要扩展存储层和数据层即可,展示层和业务层无须变动。
2.面向服务拆分:对某个服务扩展,或者要增加新的服务时,只需要扩展相关服务即可,无须修改所有的服务。同样以学生管理系统为例,如果我们需要在注册服务中增加一种“学号注册”功能,则只 需要修改“注册服务”和“登录服务”即可,“信息管理服务”和“安全设置”服务无须修改。
3.面向功能拆分 对某个功能扩展,或者要增加新的功能时,只需要扩展相关功能即可&