前几天,有园友私下问我,博客中的AccountDemo后端架构为什么是那样的,是不是分层太多太冗余,故这里简单介绍下。先看解决方案工程截图:

  

  每个工程的含义,见https://www.cnblogs.com/guokun/p/7082987.html。运行时,请求处理流程,这里再贴出来:

  

  这里,园友主要不解的是,为什么会有两个接口层,Account.Repository.Contract和Account.Service.Contract,是不是太多了。最近几年,在后端架构中,出现了一种称之为六边形架构的架构模式,这货之前曾被叫做洋葱架构、端口适配器架构,反正大家知道都是它就是了。六边形架构的核心,就是应用程序业务逻辑处于架构的核心,而上层的视图、控制器、数据访问等,都属于基础设施,是用来辅助实现业务逻辑的,他们都依赖于核心业务逻辑。这些基础设施是易变或者说很可能被频繁替换的,例如应用层今天可能是MVC,明天可能是WebAPI,数据访问今天可能是EF,明天可能是Dapper,甚至CSRedis,MongoDB。。。

  六边形架构最终要实现的效果就是,解耦应用核心业务逻辑与基础设施,其整体架构与依赖如下图:

  

  蓝色箭头方向代表依赖方向,而非运行时数据流向或请求处理流向,请特别注意。ApplicationCore处于整个架构的中心,周边都是依赖于它的,这也是这一层名称ApplicationCore的由来,其核心特征是:1、用用层及基础设施层都依赖核心业务层;2、业务逻辑保持不变,应用层或基础设施层,比如切库、切ORM、切应用层框架,随便搞;3、有别于传统三层架构,数据层提供什么,业务层就有什么或用什么,六边形架构是业务层需要什么,就定义什么契约,数据层就实现什么或提供什么。

  介绍完了六边形架构,接下来回答,为什么有两个接口层。本质上,Account.Repository.Contract和Account.Service.Contract两层契约均归属于核心业务层,Account.Service.Contract用于对应用层承诺,提供什么服务,Account.Repository.Contract和Account.Service.Contract则规定基础设施层必须给自己提供什么操作。如果你愿意,那么这两个接口层完全可以融入Account.Service工程中,这都是没问题的,本来他们就属于业务逻辑的范畴,但我还是把它单独分出来,否则便是应用层、基础设施层直接硬依赖Account.Service,一者太重,二者不符合将面向接口编程。

  最后,说下,为什么Account.Repository.EF仓储工程中,一个实体类,对应了一个仓储对象。严格来讲,这么做是不合适的,设想一下,假如数据库表很多,那这里岂不膨胀得厉害。要弄明白这个问题,首先得知道仓储的由来。这玩意儿来自领域驱动架构,一般来讲,一个仓储是一一对应一个聚合根,这个聚合根是业务上功能聚合的一系列领域对象的,例如一个学生,对应一个宿舍,同时这个学生是个高富帅,他他妈的比较花心,身边有N个白富美女朋友。如果系统要维护这么样一个对应关系或信息,这里学生就是一个聚合根。具体表现在代码中,直观看就类似一个复杂对象,这个复杂对象的最外边就是学生,里边嵌套啥宿舍啊,女朋友集合啊,什么的。正常情况下,应该是学生这个聚合根才对应一个仓储类的,什么宿舍,女朋友都不应该有仓储类(假设没有其他需求导致他们需要上升为聚合根)。解释完了聚合根,这里回到刚才那问题,为什么搞成了一个数据库实体一个仓储类。主要在于,示例中抽象出了这么一个仓储基类:

这玩意儿是泛型的,因为后续仓储实现类想要用到其中的一些公用方法,实现这个基类时候,需要约定实体,所以为了偷懒,我就每个数据库表或者领域实体一个仓储类了,仅此而已。

好了,园友提到的几个问题差不多就这样。

Account的简单架构的更多相关文章

  1. android APP是否需要缓存?+简单架构

    问题的由来 昨天,当我写完我的第一篇博客之后,我便百无聊赖的玩起了手机!当我打开Google自带的一些app的时候,发现他们直接叫我连接网络,并没有缓存上次从网络获取的数据.这就让我感到很奇怪!于是我 ...

  2. PHP网站简单架构 – 单独跑php-fpm

    这个架构比较简单,不做过多的说明 前端1台Nginx:负载均衡+nfs 中间2台php:php-fpm 后端1台数据库:MySQL 安装略,参考<lnmp最新源码一键安装包> 192.16 ...

  3. 简单架构:反射实现抽象工厂+IDAL接口完全独立DAL

    一.普通架构中存在的问题 StudentDB数据库,包含一张StudentInfoTB表,结构如下: s_id int primary key identity(1,1), s_name Nvarch ...

  4. 重构 JAVA 聊天室 —— CS 模式的简单架构实现

    前言 自从开始弄起数据挖掘之后,已经很久没写过技术类的博客了,最近学校 JAVA 课设要求实现一个聊天室,想想去年自己已经写了一个了,但是有些要求到的功能我也没实现,但看着原有的代码想了想加功能好像有 ...

  5. [转]分享php中四种webservice实现的简单架构方法及实例

    FROM : http://www.itokit.com/2012/0417/73615_2.html 本人所了解的webservice有以下几种:PHP本身的SOAP,开源的NUSOAP,商业版的P ...

  6. 分享php中四种webservice实现的简单架构方法及实例

    一:PHP本身的SOAP所有的webservice都包括服务端(server)和客户端(client).要使用php本身的soap首先要把该拓展安装好并且启用.下面看具体的code首先这是服务端实现: ...

  7. 分享php中四种webservice实现的简单架构方法及实例(转)

    本人所了解的webservice有以下几种:PHP本身的SOAP,开源的NUSOAP,商业版的PHPRPC,以及使用二进制传输数据流的 HessianPHP,那么一下就简单的介绍下这几种webserv ...

  8. 分享php中四种webservice实现的简单架构方法及实例[转载]

    [转载]http://www.itokit.com/2012/0417/73615.html 本人所了解的webservice有以下几种:PHP本身的SOAP,开源的NUSOAP,商业版的PHPRPC ...

  9. web开发之负载均衡的简单架构

    负载均衡 负载均衡的核心思想就是:请求分担 最简单的配置: 一台负载均衡服务器 两台webserver服务器 两台webserver服务器需要配置相同的服务器环境,设置相同的域名指向 负载均衡服务器需 ...

随机推荐

  1. (转)sublime text3简体中文版汉化教程

    preferens——package controller——输入 install package——等待安装完成后输入 localizationChinese 请使用主菜单的 帮助/Language ...

  2. typescript枚举,类型推论,类型兼容性,高级类型,Symbols(学习笔记非干货)

    枚举部分 Enumeration part 使用枚举我们可以定义一些有名字的数字常量. 枚举通过 enum关键字来定义. Using enumerations, we can define some ...

  3. Jenkins-Pipeline 流水线发布部署项目

    node { sh 'mkdir -p cms' dir('cms') { git branch: 'prerelease', credentialsId: '5fb79ef0-4301-4b7c-a ...

  4. 爬虫处理网站的bug---小于号未转化为实体符

    1.发现BUG 爬取 chinadrugtrials 详情页的公示的试验信息时候, 发现程序在某些地方跑断掉了,如下: 经排查发现,原来这是网页的bug-----极少数详情页面的某些文字中的小于号,未 ...

  5. 安装Cloudera manager agent步骤详解

    安装Cloudera manager agent步骤详解 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 本篇博客主要是针对:https://www.cnblogs.com/yinz ...

  6. 记录一个elasticsearch 的索引templates

    搞了好长时间终于成了. { "order": 0, "version": 50001, "template": "click.*& ...

  7. JAVA 远程通讯机制

    在分布式服务框架中,一个最基础的问题就是远程服务是怎么通讯的,在Java领域中有很多可实现远程通讯的技术,例如:RMI.MINA.ESB. Burlap.Hessian.SOAP.EJB和JMS等,这 ...

  8. python---ORM之SQLAlchemy(4)relationship多对多练习

    练习一:朋友 import sqlalchemy from sqlalchemy import create_engine from sqlalchemy import Column, String, ...

  9. Linux命令(九)查找文件find

    4. find -type f   文件 d  目录 l   连接 5. find -size 6. find -maxdepth -2 (最深路径为2) 7. find ./ -maxdepth 1 ...

  10. asp.net mvc4 在EF新增的时候报对一个实体或多个实体验证失败

    //entity为空 是数据库上下文会验证实体验证 var entity = db.UserInfo.Where(u => u.Mobile == mobile).FirstOrDefault( ...