代码分层设计:从MVC到四层架构
创作时间:
作者:
@小白创作中心
代码分层设计:从MVC到四层架构
引用
1
来源
1.
https://tool.lu/vi_VN/article/1qQ/preview
在软件开发中,良好的代码分层设计可以使代码的耦合性大大降低,易用性大大增强,为系统的微服务化和模块化拆分打下良好的基础。本文将详细介绍代码分层设计的基本概念、常用领域模型以及四层结构设计的具体实现。
在搭建一个项目之前,除了要进行架构和业务方面的设计和分析,往往还需要对代码的结构进行规范化设计。而分层思想,是应用系统最常见的一种架构模式。
我们会将系统进行横向切割,根据业务职责划分,这就是代码分层。这样划分的目的是规范软件系统的逻辑结构,以便于后期开发和维护。
一个软件系统就像一幅传世名画,在色彩和线条的表面之下,是精妙的几何结构。席里柯的《梅杜莎之筏》,画高五米,宽超七米,结构宏伟,气势磅礴,人体的塑造坚实而有力。尤其是它的画面上,由十几个人构成了两个金字塔式的几何图形。这些就是古典主义的特色。
上面是题外话,下面继续介绍代码分层。
我们熟悉的MVC(Model-View-Controller,分别是模型层、视图层、控制层)三层架构就是非常典型的分层架构模式。它将页面和业务逻辑分离,提高应用的可扩展性及可维护性。
MVC 三层架构只是概念层面的指导思想,如果想要让开发更规范、职责更明确、层次更清晰,需要下面更为细致的代码分层设计。
在介绍代码的分层之前,需要先了解代码分层结构中的领域模型。下面介绍几个常用的领域模型,其中参考了阿里巴巴编码规范的设计。
- DO(Data Object):与数据库表结构一一对应,通过 DAO 层向上传输数据源对象。
- DTO(Data Transfer Object):是远程调用对象,它是 RPC 服务提供的领域模型。需要注意的是,对于 DTO 一定要保证其序列化,实现 Serializable 接口,并显示提供 serialVersionUID,否则在反序列化时,如果 serialVersionUID 被修改,那么反序列化会失败。
- BO(Business Object):是业务逻辑层封装业务逻辑的对象,一般情况下,它是聚合了多个数据源的复合对象。
- VO(View Object):通常是请求处理层传输的对象,它通过 Spring 框架的转换后,往往是一个 JSON 对象。
在传统的MVC三层结构的基础之上,我们将业务系统设计为如下四层结构:前端层、请求处理层、业务逻辑层和持久层。
下面详细介绍一下各个分层的作用。
- 前端层:内容涵盖了从系统外发起的一切请求,还包括定时任务的触发配置,以及系统的监控和检测程序。
- 请求处理层:作用包括通过模板引擎(FreeMarker、Velocity等)的页面渲染、封装RESTful API的HTTP接口,以及暴露给前端调用的各种类型的接口。
- 业务逻辑层:职责是与数据持久层交互,包括对多个数据源的操作进行聚合,并且提供组合复用的能力。如果网站采用分布式架构,或者数据库需要分库,也包括对RPC服务的统一调用,为了减少不必要的重复调用RPC服务,RPC Service中对数据进行统一处理以后再返回给Manager,是一个节省RPC连接的做法。此外,它也是业务通用能力的处理层,其中还包括缓存方案、消息监听(MQ)、定时任务、参数校验、数据转换、异常处理等。
- 数据持久层:承载了数据存储和访问的能力。包括通过DAO访问数据库的能力和通过DAP访问外部数据接口的能力。
良好的代码分层设计可以使代码的耦合性大大降低,易用性大大增强,为系统的微服务化和模块化拆分打下良好的基础。
热门推荐
绩效评价调查问卷怎么设计才科学?
美术生一般用几k的画纸?如何选择合适的尺寸?
腰椎间盘突出:从病因到治疗
腰椎间盘突出症好发于哪些人
如何开发一款给视频打马赛克自动跟随的软件
瑞虎8油耗大怎么办?三招教你轻松省油
醋泡花生做法大全:五种美味又健康的减肥食谱
从零开始Hadoop安装和配置(超详细图文步骤)
每天坚持吃一个煮熟的苹果,有什么好处?这5类人不妨多吃
预算管理策略:优化资源配置,提升企业财务效能
股票与债券有什么区别
水瓶座男对待感情的态度及其特点解析
芭蕉美人蕉北方会种吗?温室栽培是关键
唐三插曲我都比比东不亦乐乎:探讨唐三与比比东复杂关系对剧情的影响
知止而后有定,定而后能静,静而后能安,安而后能虑,虑而后能得
满月酒的由来、意义及日期讲究
充电:了解低能量和疲劳
GPA评定标准详解:从定义到影响
如何查询数据库大小
5块硬盘做raid几合适?求分析
胶带的使用方法与应用领域
新民晚报|全过程人民民主保障“全人群”参与
邓玉娇案件回顾与社会影响:从法律视角解析其现状
精神病患者如何申请残疾证?全流程指南来了
死亡证明会写明死亡原因吗?
败血症的定义、病因、症状及治疗
普通人怎么才能识别AI作图的真假
Excel表格中实现相同数据(重复值)标红的几种方法详解
Excel 公式查找一列中的重复项(8 种简单方法)
如何确定资产配置中黄金的合理比例?不同比例对投资组合的影响如何?