解耦的艺术_应用架构中的解耦

文章目录

  • Pre
  • 解耦的技术演化
  • 应用架构中的解耦
  • 小结

在这里插入图片描述

Pre

解耦的艺术_通过DPI依赖倒置实现解耦

解耦的艺术_通过中间层映射实现解耦


解耦的技术演化

技术的演化史,也是一部解耦的历史。从最初的面向对象编程(OOP)到Spring框架的依赖注入,再到分布式架构中的微服务,技术的每一次进步都伴随着解耦的推进。

  • 原始社会:最初的编程往往是“高耦合”的,创建对象的过程没有解耦机制,每个对象都由开发人员手动管理。

    UserService userService = new UserService(); // 直接依赖UserService
    
  • 工业社会:随着工厂模式(Factory Pattern)的引入,开发人员不再自己创建对象,而是通过工厂来进行管理,帮助我们将对象的创建和使用分离,完成了初步的解耦

    UserServiceFactory factory = new UserServiceFactory();
    UserService userService = factory.createUserService();
    
  • 共产主义社会:随着依赖注入(DI)技术的普及,特别是Spring框架的引入,解耦进一步得到提升。应用不再关心如何创建对象,而是通过依赖注入由框架自动管理对象的生命周期和依赖关系

    @Service
    	public class BusinessService {
    	    @Autowired
    	    private UserService userService;
    	    
    	    // 业务逻辑...
    	}
    
  • 分布式时代:随着分布式系统的崛起,RPC技术解决了系统之间的通信问题,但仍面临着技术依赖的问题。Web Service和RESTful架构的出现,则进一步降低了分布式系统中的耦合度,支持平台无关和语言无关的服务调用。


应用架构中的解耦

Robert C.Martin在其博客文章“The Clean Architecture”中提出的观点:应用架构之道,就是要实现业务逻辑和技术细节的解耦

不管是六边形架构、洋葱圈架构,还是COLA架构,其核心要义都是做核心业务逻辑和技术细节的分离和解耦。

试想,如果业务逻辑和技术细节杂糅在一起,将所有的代码都写在ServiceImpl中,前几行代码负责validation,接下来几行代码负责convert,然后是几行业务逻辑代码,之后我们需要通过RPC或DAO获取更多的数据,拿到数据后,又是几行convert的代码,再接上一段业务逻辑代码,最后还要落库、发消息,等等。按照上面这种写代码的方式,再简单的业务都会变得复杂且难以维护

COLA 1.0

在这里插入图片描述
让领域层(Domain Layer)对基础设施层(Infrastructure Layer)进行直接依赖比较方便,而且似乎也没什么大问题.

然而实际上,这种“偷懒”的行为有悖于框架设计的初衷,因为在设计之初,我们就希望领域层是应用的核心,类似于洋葱圈架构所提倡的——让领域层处于架构的中心位置,即洋葱圈最核心的部分。也就是说,领域层不应该依赖基础设施层,相反地,应该让基础设施层依赖于领域层。

如果让领域层依赖基础设施层,会“污染”领域层的纯粹性,影响其独立性和可测试性。也就是说,层次之间不再是正交的了,基础设施层的任何变动都可能影响到领域层,而这不是我们想看到的。

COLA 2.0

COLA 2.0时,特意使用依赖倒置反转了领域层和基础设施层的依赖关系.

在这里插入图片描述
COLA 2.0的核心变化是领域层不再直接依赖基础设施层,而是通过一个新的抽象Gateway(网关)对领域层和基础设施层进行了解耦,这两个层次不再彼此依赖、彼此耦合,而是都依赖于Gateway .

举个例子,假如某个应用中需要用到类目(Category)这个实体,但是类目又不在本域中,需要通过一个RPC调用才能获取相应的信息。那么这时我们就可以在领域层中定义一个类目网关(CategoryGateway),这是一个纯抽象的概念

public interface CategoryGateway{
	Category getCategoryById(Long categoryId);

}

这个抽象相当于告诉基础设施层:你需要按照这个接口来提供数据。至于这个数据是如何被获取、被组装、被转换的,都是基础设施层需要关心的事情,不再需要领域层去关心.

综上,通过依赖倒置方式,我们倒置了领域层和基础设施层的依赖关系,让两个模块从原来的依赖关系变成了正交关系,两者可以独立地改动和变化,而不会影响到另一方。

例如,要想让类目信息的获取从RPC变成本地数据库调用,那么我们只需要修改基础设施层的代码即可,领域层可以完全不动。同理,如果在领域层有关于类目的业务变化,比如原来需要通过三级类目去判断同类品的逻辑,现在要放宽到二级类目,这种变化也不会影响到基础设施层的代码


小结

  • “高内聚、低耦合”是软件设计追求的重要目标之一,组件、模块、层次设计都应该遵循“高内聚、低耦合”的设计原则。
  • 正交的关键在于如何识别耦合性,我们可以通过识别系统需要扩展的地方来识别耦合性。比如,关于配置系统的设计不应该耦合于某一种特定的实现方式,而是应该更灵活一些。
  • 解耦主要有依赖倒置和中间层映射两种方式。
  • 我们要尽可能多地依赖抽象而不是具体,这能使系统更灵活,这种编程方式也叫作面向接口编程。
  • “计算机中的任何问题,都可以通过加一层来解决”,中间层的价值也在于解耦。

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/975296.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Python采用DeepSeekR1本地部署+本地API接口实现简单对话

以下内容摘抄自 【Ai】— DeepSeek-r1 版本选择(超详细)https://blog.csdn.net/weixin_44205779/article/details/145479506 Ollama:零代码部署大模型,轻松玩转AIhttps://blog.csdn.net/scy799327210/article/details/145798396 大模型 ollama命令详解大全https://blog.…

记录 pycharm 无法识别提示导入已有的模块解决方案 No module named ‘xxx‘

在windows下,使用pycharm开发项目,每个项目都有自己独立的虚拟环境,有时候就会出现,在该项目中明明已经安装了某个模块,但是在写代码的时候就是导入不了,无法识别导入,在运行的时候却又是正常的…

uniapp 网络请求封装(uni.request 与 uView-Plus)

一、背景 在开发项目中,需要经常与后端服务器进行交互;为了提高开发效率和代码维护性,以及降低重复性代码,便对网络请求进行封装统一管理。 二、创建环境文件 2.1、根目录新建utils文件夹,utils文件夹内新建env.js文…

【OpenCV】入门教学

🏠大家好,我是Yui_💬 🍑如果文章知识点有错误的地方,请指正!和大家一起学习,一起进步👀 🚀如有不懂,可以随时向我提问,我会全力讲解~ &#x1f52…

解决双系统开机显示gnu grub version 2.06 Minimal BASH Like Line Editing is Supported

找了好多教程都没有用,终于解决了!!我是因为ubuntu分区的时候出问题了 问题描述: 双系统装好,隔天开机找不到引导项,黑屏显示下列 因为我用的D盘划分出来的部分空闲空间,而不是全部&#xff0c…

计算机毕业设计Hadoop+Spark+DeepSeek-R1大模型民宿推荐系统 hive民宿可视化 民宿爬虫 大数据毕业设计(源码+LW文档+PPT+讲解)

温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 作者简介:Java领…

Visual Studio Code 2025 安装与高效配置教程

一、软件简介与下载 1. Visual Studio Code 是什么? Visual Studio Code(简称VS Code)是微软推出的免费开源代码编辑器,支持 智能代码补全、Git集成、插件扩展 等功能,适用于前端开发、Python、Java等多种编程场景。…

【Node.js】express框架

目录 1初识express框架 2 初步使用 2.1 安装 2.2 创建基本的Web服务器 2.3 监听方法 2.3.1 监听get请求 2.3.2 监听post请求 2.4 响应客户端 2.5 获取url中的参数(get) 2.5.1 获取查询参数 2.5.2 获取动态参数 2.6 托管静态资源 2.6.1 挂载路径前缀 2.6.2 托管多…

YOLOv8与DAttention机制的融合:复杂场景下目标检测性能的增强

文章目录 1. YOLOv8简介2. DAttention (DAT)注意力机制概述2.1 DAttention机制的工作原理 3. YOLOv8与DAttention (DAT)的结合3.1 引入DAT的动机3.2 集成方法3.3 代码实现 4. 实验与结果分析4.1 实验设置4.2 结果分析推理速度性能对比 5. 深度分析:DAttention在YOLO…

ARMS 助力假面科技研发运维提效,保障极致游戏体验

客户介绍与项目背景 假面科技成立于 2014 年,致力于打造创新的数字产品,火爆一时的“狼人杀”、“谁是卧底”、“足记相机”都是假面科技旗下产品,公司产品总数超过 40 款,覆盖用户数超过 2 亿人。 随着业务的持续发展&#xff…

WPF的页面设计和实用功能实现

目录 一、TextBlock和TextBox 1. 在TextBlock中实时显示当前时间 二、ListView 1.ListView显示数据 三、ComboBox 1. ComboBox和CheckBox组合实现下拉框多选 四、Button 1. 设计Button按钮的边框为圆角,并对指针悬停时的颜色进行设置 一、TextBlock和TextBox…

javaEE-14.spring MVC练习

目录 1.加法计算器 需求分析: 前端页面代码: 后端代码实现功能: 调整前端页面代码: 进行测试: 2.用户登录 需求分析: 定义接口: 1.登录数据校验接口: 2.查询登录用户接口: 前端代码: 后端代码: 调整前端代码: 测试/查错因 后端: 前端: lombok工具 1.引入依赖…

[实现Rpc] 服务端 | RpcRouter实现 | Builder模式

目录 项目服务端独用类的实现 1. RpcRouter类的实现 ServiceDescribe SDescribeFactory ⭕ Builder模式 1. 动机 2. 模式定义 3. 要点总结 4. 代码感受 ServiceManager RpcRouter 4. 代码感受 ServiceManager RpcRouter 前文我们就将 Rpc 通用类都实现完啦&#…

js 实现隔行幻色

构建界面&#xff1a;html&#xff1a; <table cellspacing"0"><!-- 表格中的单元格设为0&#xff0c;没间距 --><thead><tr><td>序号</td><td>姓名</td><td>操作</td></tr></thead><tb…

影刀RPA中级证书-Excel进阶-开票清单

1.操作题需求 请参照视频内容&#xff0c;将开票账单表格中的数据整理成开票清单。请下载 开票账单.xlsx 整理规则如下&#xff1a; 1. 金额为0的数据为赠品&#xff0c;无需开票&#xff0c;需删除2. 开票清单需要从开票账单中获取的数据包括有开票名称、数量、金额、税率&…

tortoiseGit的使用和上传拉取

tortoiseGit的使用和上传拉取 下载TortoiseGit 通过网盘分享的文件&#xff1a;tortoiseGit.zip 链接: https://pan.baidu.com/s/1EOT_UsM9_OysRqXa8gES4A?pwd1234 提取码: 1234 在电脑桌面新建文件夹并进入 右击鼠标 将网址复制上去 用户名和密码是在git注册的用户名和…

从0到1:固件分析

固件分析 0x01 固件提取 1、从厂商官网下载 例如D-link的固件&#xff1a; https://support.dlink.com/resource/products/ 2、代理或镜像设备更新时的流量 发起中间人攻击MITM #启用IP转发功能 echo 1 > /proc/sys/net/ipv4/ip_forward#配置iptables&#xff0c;将目…

JVM预热

阿里电商平台每年的各种大促活动&#xff0c;对于Java技术来说&#xff0c;其中重要一个操作环节就是预热操作。 目录 预热是什么&#xff1f;为什么要预热&#xff1f; java 程序不预热和预热的调用对比 预热是什么&#xff1f; 预热是指&#xff0c;在 JVM 启动后&#xff0…

Datawhale Ollama教程笔记5

Dify 接入 Ollama 部署的本地模型 Dify 支持接入 Ollama 部署的大型语言模型推理和 embedding 能力。 快速接入 下载 Ollama 访问 Ollama 安装与配置&#xff0c;查看 Ollama 本地部署教程。 运行 Ollama 并与 Llama 聊天 ollama run llama3.1Copy to clipboardErrorCopied …

springboot+dubbo+zookeeper的注册服务和调用实践

目录 zookeeper为什么可作为注册中心zookeeper注册中心优缺点启动zookeeper编写springboot项目提供dubbo服务1. 服务接口2. Springboot引入dubbo实现服务接口2.1 工程目录和依赖2.2 启动程序和application.properties2.3 DubboService 实现服务接口2.4 测试api&#xff0c;用于…