分层是架构设计的常用方法,也是指导我们做架构设计、功能设计的重要思想。运用好分层能帮我们解决工作中许多难题,下面分三部分来介绍分层:典型分层架构、无处不在的分层思想、如何分层。
我们主要介绍三种经典分层架构。
上图是一个典型的微服务架构分层示意图。客户端代表用户的App。
我们考虑一个问题,微服务架构一定要分网关层、业务逻辑层、数据访问层、数据库这四层么?答案是否定的。四层架构只是一个相对优化的方案,对不同的业务规模不同的业务场景会有很多变化。
比如,我们在项目初期,数据结构可能比较单一,没必要把业务逻辑层和数据访问层过早的分离,这样只会徒增服务维护的成本。一种比较好的方式是把对数据库的访问封装成公共的jar包,在业务逻辑层大家都调用相同的jar包去访问数据库就可以了。随着业务发展,以后要抽离数据访问层为单独服务时改造成本也比较低。再比如随着业务发展,业务逻辑层出现一些需要其他服务调用的模块,我们可以把业务逻辑层再分为两层,公共业务逻辑层和个性化业务逻辑层,以增加代码逻辑的复用性。
微服务分层架构还有一个调用原则,只允许上层调用下层的服务,不允许同层和反向的调用,以此来避免产生循环依赖。微服务通过分层解决服务的耦合、理清调用关系、加速业务开发。
上图是典型的网络五层架构分层模型图。
网络是为了完成计算机之间的数据通信。
网络的五层架构分别负责不同的功能,最终完成数据从一台计算机应用程序到达另一台计算机应用程序的传输。分层之后物理层和数据链路层主要由硬件厂商来负责,网络层和传输层主要由操作系统负责,应用层由应用程序开发者来负责。
通过分层把复杂的问题简单化,大家的分工也更加明确了。
思考:网络可以不是五层架构么?
MVC是非常典型的应用程序开发架构,刚毕业接触Java开发时,Spring框架的MVC模式深入我心。 M:Model业务模型。 V:View视图,用户看到的交互页面。 C:Controller控制器,接收用户的请求,调用View和Model输出用户需要的数据。
通过业务模型、视图、控制器三层划分,在开发web应用时,可以在不同文件夹中聚焦业务代码。不同的控制器可以组合不同的业务模型和视图,也增加了代码复用性。
前面介绍的都是一些经典分层架构,其实分层架构和思想,可以体现在我们工作的方方面面。
这是一个web前端项目的分层架构示意图。
通过分层可以方便我们组织代码结构,也方便代码逻辑的复用,比如多个页面用到了相同的数据,那就可以在多个页面调用相同的数据逻辑层函数。
这是一个web接口服务的分层架构示意图。
之前在360人工智能研究院做智能外呼项目时,我们也是利用分层的思想设计服务的整体架构。
首先我们把业务分成分成线上服务和支撑服务两层,把数据存储抽象出存储层。线上服务直接对外提供语音交互功能,支持服务负责配置数据、采集日志等。
线上服务我们又分成接入层、中控、算法三层。其中接入层类似于网关,负责用户鉴权、流量转发、生成Session等,中控负责根据策略调度算法服务,算法层实现具体的算法逻辑。
通过两次分层,理清了整个业务各模块之间的关系,划分好了各模块的主要功能,既减少模块之间功能的耦合也方便服务的开发、部署、升级。
既然分层思想如此重要,我们应该怎么更好使用呢?我总结了一些使用规则。
分层架构是我们做系统架构设计不可缺少的思想。大到系统总体架构,小到一个函数库封装都能体现出分层的设计思想。
分层起到的作用有:功能内聚,解耦,增强代码复用性,明确调用关系避免循环依赖,方便代码结构组织,方便业务扩展等。
以上就是我对分层的理解,欢迎私信交流。
Copyright© 2013-2020
All Rights Reserved 京ICP备2023019179号-8