为什么阿里建议给MVC三层架构多加一层Manager层?

你好,我是蜗牛!

大家应该都知道 MVC(Model-View-Controller)架构。

图片

MVC三层架构

图片

三层架构示意图

MVC架构弊端

传统的MVC分层有以下几个很明显的问题:

图片

为了解决这个问题,我们在Service层之下再独立出一个通用业务处理层(Manager层)

图片

Manager层

在这个分层架构中主要增加了 Manager 层,它与 Service 层的关系是:Manager 层提供原子的服务接口,Service 层负责依据业务逻辑来编排原子接口。

Manager层的特征

在《alibaba java开发手册》中是这样描述Manager层的:

图片

在实际开发中我们可以这样使用Manager层
  1. 复杂业务,service提供数据给Manager层,负责业务编排,然后把事务下沉到Manager层,Manager层不允许相互调用,不会出现事务嵌套。

  2. 专注于不带业务sql语言,也可以在manager层进行通用业务的dao层封装。

  3. 避免复杂的join查询,数据库压力比java大很多,所以要严格控制好sql,所以可以在manager层进行拆分,比如复杂查询。

当然对于简单的业务,可以不使用Manager层。

Manager层使用案例

这里我们举个例子说明一下Manager层的使用场景:

图片

图片

图片

接下来我们看一段实际代码说明一下Service层与Manager层如何进行区分?

图片

上面代码在我们在我们采用三层架构时经常会遇到,那么它有什么问题呢?

上面的代码是典型的长事务问题,前三步都是使用 connection 进行验证操作,但是由于方法上有@Transactional 注解,所以这三个验证都是使用的同一个 connection。

若对于复杂业务、复杂的验证逻辑,会导致整个验证过程始终占用该 connection 连接,占用时间可能会很长,直至方法结束,connection 才会交还给数据库连接池。

对于复杂业务的不可预计的情况,长时间占用同一个 connection 连接不是好的事情,应该尽量缩短占用时间。后台回复关键词 笔记 获取蜗牛哥整理的实战笔记 持续更新

图片

所以我们在加入Manager层以后可以这样写:

图片

将数据在 service 层准备好,然后传递给 manager 层,由 manager 层添加@Transactional事务注解进行数据库操作。

最后说一句(求关注!别白嫖!)

如果这篇文章对您有所帮助,或者有所启发的话,求一键三连:点赞、转发、在看。

关注公众号:woniuxgg,在公众号中回复:笔记  就可以获得蜗牛为你精心准备的java实战语雀笔记,回复面试、开发手册、有超赞的粉丝福利!

相关推荐

最近更新

  1. TCP协议是安全的吗?

    2024-01-27 11:12:05       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-01-27 11:12:05       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-01-27 11:12:05       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-01-27 11:12:05       18 阅读

热门阅读

  1. 如何创建线程

    2024-01-27 11:12:05       29 阅读
  2. [GN] Vue3.2 快速上手 ---- 组件通信

    2024-01-27 11:12:05       35 阅读
  3. CF1029E Tree with Small Distances 题解

    2024-01-27 11:12:05       38 阅读
  4. TiDB中Table映射到KV

    2024-01-27 11:12:05       31 阅读
  5. nginx做盗链与防盗链配置

    2024-01-27 11:12:05       26 阅读
  6. 常用的gpt-4 prompt words收集8

    2024-01-27 11:12:05       25 阅读
  7. php 源码加密保护 bease方案

    2024-01-27 11:12:05       26 阅读
  8. android studio开发的一些问题

    2024-01-27 11:12:05       35 阅读