博客
关于我
.NET Core开发实战(第26课:工程结构概览:定义应用分层及依赖关系)--学习笔记
阅读量:450 次
发布时间:2019-03-06

本文共 1565 字,大约阅读时间需要 5 分钟。

工程结构概览:定义应用分层及依赖关系

从这一节开始进入微服务实战部分。本节将详细讲解工程的结构和应用的分层设计。

项目结构概述

在本节中,我们将探讨一个典型的微服务架构,具体分析其分层设计与依赖关系。该架构分为四个主要层次,每个层次承担不同职责,通过清晰的分层设计和依赖关系,实现了系统的模块化与可维护性。


分层设计

本项目采用了四层结构设计,每层都有明确的职责划分:

1. 领域模型层

领域模型层是业务逻辑的核心,专注于定义业务模型。这里定义了各个领域的聚合和领域事件。每个聚合通常对应一个或多个实体类,领域事件用于捕捉业务流程中的重要状态变化。该层与其他层无直接依赖,保持高度的独立性。

2. 基础设施层

基础设施层主要负责数据存取与事务管理。该层定义了仓储接口和实现,包括Entity的仓储、EFContext等基础组件。该层依赖于领域模型层的定义,例如通过仓储接口与领域模型进行交互。

3. 应用层

应用层是系统的入口与服务集成层,主要包含以下子层次:

  • Web层:负责接收前端请求并返回响应,定义API接口。
  • 后台任务层:用于执行定期任务或批量处理,作为Job的宿主运行。

4. 共享层

共享层提供通用功能,供其他层复用。主要包括:

  • GeekTime.Core:定义基础类型,如异常类和帮助类。
  • GeekTime.Domain.Abstractions:定义领域抽象,包括领域事件接口、Entity接口等。
  • GeekTime.Infrastructure.Core:提供EFContext等基础设施组件。

依赖关系

各层之间的依赖关系设计得非常清晰:

  • 共享层:不依赖任何层,作为通用库供其他层使用。
  • 基础设施层:依赖领域模型层,实现仓储功能。
  • 应用层:依赖基础设施层,用于数据存取和事务管理。

通过这种依赖关系设计,各层之间实现了松耦合的依赖,减少了紧耦合带来的维护成本。


仓储层实现

仓储层是数据持久化的核心,主要实现了以下功能:

public interface IRepository
where TEntity : Entity
, IAggregateRoot
{ Task
FindAsync(TKey id, CancellationToken cancellationToken = default);}

仓储实现类OrderRepository继承自通用仓储实现,并与EFContext集成:

public class OrderRepository : Repository
: IOrderRepository{ public OrderRepository(DomainContext context) : base(context) { }}

仓储层通过IRepository接口与领域模型层交互,确保代码复用性。


事务管理

事务管理通过DomainContextTransactionBehavior实现,自动管理请求上下文中的事务。这种设计简化了事务处理逻辑,避免了手动管理。


CQRS 设计

应用层采用了CQRS(命令与查询职责分离)模式,将命令和查询分离到不同的目录中。通过这种方式,系统架构变得更加清晰,团队协作更加高效。


总结

本文详细讲解了微服务架构中工程分层及依赖关系的设计原则。通过清晰的层次划分和松耦合的依赖关系设计,实现了系统的高效维护与扩展。

在实际开发中,可以通过私有NuGet仓库管理共享包,确保各层之间的代码复用性和协同开发。这种架构设计不仅提升了系统的可维护性,还为团队的协作效率提供了有力支持。

转载地址:http://ypkkz.baihongyu.com/

你可能感兴趣的文章
Oracle 在Drop表时的Cascade Constraints
查看>>
Oracle 在Sqlplus 执行sql脚本文件。
查看>>
Oracle 如何处理CLOB字段
查看>>
oracle 学习
查看>>
oracle 定义双重循环例子
查看>>
ORACLE 客户端工具连接oracle 12504
查看>>
Oracle 客户端连接时报ORA-01019错误总结
查看>>
oracle 导出sql数据库表结构,使用sql developer 导出Oracle数据库中的表结构
查看>>
oracle 嵌套表 例子,Oracle之嵌套表(了解)
查看>>
Oracle 常用命令
查看>>
Oracle 常用的V$视图脚本(二)
查看>>
Oracle 并行原理与示例总结
查看>>
oracle 并集 时间_Oracle集合运算符 交集 并集 差集
查看>>
Oracle 序列sequence 开始于某个值(10)执行完nextval 发现查出的值比10还小的解释
查看>>
oracle 执行一条查询语句,把数据加载到页面或者前台发生的事情
查看>>
oracle 批量生成建同义词语句和付权语句
查看>>
oracle 抓包工具,shell 安装oracle和pfring(抓包) 及自动环境配置
查看>>
Oracle 拆分以逗号分隔的字符串为多行数据
查看>>
Oracle 排序中使用nulls first 或者nulls last 语法
查看>>
oracle 插入date日期类型的数据、插入从表中查出的数据,使用表中的默认数据
查看>>