热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

领域驱动_领域驱动(DDD)之我见,基于Golang实现

本文由编程笔记#小编为大家整理,主要介绍了领域驱动(DDD)之我见,基于Golang实现相关的知识,希望对你有一定的参考价值。分享一点不成熟的理解,还请本着交流进步的大原则喷之
本文由编程笔记#小编为大家整理,主要介绍了领域驱动(DDD)之我见,基于Golang实现相关的知识,希望对你有一定的参考价值。


分享一点不成熟的理解,还请本着交流进步的大原则喷之。从去年开始接触和套用DDD以来,已经有1年多时间了。也先后在2个生产项目中主导应用,都是基于.Net Core的,完全参考https://github.com/EduardoPires/EquinoxProject 该项目搭建的基础框架。

一、一些概念

  DDD经典分层:

技术分享图片

 

 

 分层架构的一个重要原则是:每层只能与位于其下方的层发生耦合。严格分层架构,某层只能与直接位于其下方的层发生耦合;松散分层架构,则允许任意上方层与任意下方层发生耦合。大原则如此,我一般都是采用松散分层,严格的太夸张,在团队里推广起来挺难的。

  CQRS:

  命令查询职责分离,是由Betrand Meyer(Eiffel语言之父,OCP提出者)提出来的。命令(Command):不返回任何结果(void),但会改变对象的状态。查询(Query):返回结果,但是不会改变对象的状态,对系统没有副作用。在我的实践过程中,其实还是让命令返回了一些主键之类的。

  ES事件溯源:

  在CQRS中,每一个确定的命令操作,不论成功还是失败,只要执行之后就产生相应的事件(Event)。这样只需要把所有系统运行的Event,以及其产生时的数据记录起来,这就是系统的历史记录了,并且能够方便的回滚到某一历史状态。Event Sourcing就是用来进行存储和管理事件的。

  粗略的知道了这几个概念之后,基本上就可以用来理解和构建最基础的领域驱动架构了。

、一般实践

  总体分层结构如下:

技术分享图片

  1.presentation 表现层。Web框架选择了BeeGo,Beego是基于MVC的。我将V和C层都放在了表现层。路由设置、Views、以及Controllers这些统在一起都算是表现层的。领域驱动设计,更多关注的是业务,以及其变更时能够比较好的扩展与维护。表现层逻辑也很简单,主要是承接Beego框架转发过来的请求,然后通过memoryBus将请求发布出去,至于是谁订阅了该请求,统一委托给 第三方 HttpServer来处理,这也是 迪米特法则的精要。解除了表现层或者说web请求与具体的处理该请求的业务服务的直接关联(耦合)。这样做的好处,只举一例。业务层可以是独立的分布式服务,不一定跟表现层在一个进程服务里。

 技术分享图片技术分享图片

  2.application应用层。DDD里应用层是很薄的一层,只作为计算机领域到业务领域的过渡层。比如计算机能够识别和传输的肯定是2进制字节流,这一层可以充当翻译,把这些晦涩难懂的机器“语言”,转化为领域业务人员建模出来的语言。或者说是高级计算机编程语言,这里一般会有专门的ViewMode来承接所需的参数数据。这一层直接消费领域层,并且开始记录一些系统型功能,比如日志、事件溯源。

技术分享图片

  3. domain领域层。领域驱动设计里最核心的部分了,可以细拆分为聚合根、实体,领域服务等一大堆其他概念。这里不展开详细说明了,简单的理解下 聚合根,负责整个聚合业务的所有功能就行了。这里已Protocol协议为例,该类直接负责完与协议相关的所有业务,对内各种封装,完成所有所需的功能,由聚合根对外统一提供方法。

  4. infrastructure基础架构层。这一层一般主要将所有公共功能抽象整理出来,作为独立的对外输出一些帮助类等。但我这里只是重点放置了仓储功能,也就是和数据库打交道的功能。这一层也是讲求和业务逻辑无关,只重点提供通用的功能。

  5.crossutting、ddd_interfaces、dddcore,这些都不是DDD经典分层里的,主要是用来方便实现DDD所增加和分离出来的一些接口、和基础概念实现。

、一点感悟

  对DDD的理解和应用其实还很不成熟,只是对过去的一点总结。Golang 也是新手,只是看了一遍《Go语言圣经》以及astaxie大神的使用Golang构建web应用。

  确实很Go的面向对象设计,没有继承,而是采用组合的方式来实现OO里的“继承”。尽可能的使用组合而不是继承,也算是面向对象设计的一个原则,Golang天然就直接遵循了。“封装”也很有意思,直接通过首字母是否大小写,“多态”还没怎么了解透彻就不可描述了。再使用Golang实现DDD的时候,也发现了如果有“泛型”就好了的感概。这个时候更能深刻的理解和体会,泛型的好处。不得不佩服下C#的设计者,很早就有了泛型。

  简单的构造出来了一个DDD的实现,不成熟的地方还有很多,但是迭代是个好东西,慢慢的理解和完善。

  代码地址: https://github.com/KendoCross/kendoDDD

  

  

 


推荐阅读
  • 关于我们EMQ是一家全球领先的开源物联网基础设施软件供应商,服务新产业周期的IoT&5G、边缘计算与云计算市场,交付全球领先的开源物联网消息服务器和流处理数据 ... [详细]
  • 微软头条实习生分享深度学习自学指南
    本文介绍了一位微软头条实习生自学深度学习的经验分享,包括学习资源推荐、重要基础知识的学习要点等。作者强调了学好Python和数学基础的重要性,并提供了一些建议。 ... [详细]
  • 推荐系统遇上深度学习(十七)详解推荐系统中的常用评测指标
    原创:石晓文小小挖掘机2018-06-18笔者是一个痴迷于挖掘数据中的价值的学习人,希望在平日的工作学习中,挖掘数据的价值, ... [详细]
  • Python开源库和第三方包的常用框架及库
    本文介绍了Python开源库和第三方包中常用的框架和库,包括Django、CubicWeb等。同时还整理了GitHub中最受欢迎的15个Python开源框架,涵盖了事件I/O、OLAP、Web开发、高性能网络通信、测试和爬虫等领域。 ... [详细]
  • SpringBoot整合SpringSecurity+JWT实现单点登录
    SpringBoot整合SpringSecurity+JWT实现单点登录,Go语言社区,Golang程序员人脉社 ... [详细]
  • 本文由编程笔记#小编为大家整理,主要介绍了logistic回归(线性和非线性)相关的知识,包括线性logistic回归的代码和数据集的分布情况。希望对你有一定的参考价值。 ... [详细]
  • Android Studio Bumblebee | 2021.1.1(大黄蜂版本使用介绍)
    本文介绍了Android Studio Bumblebee | 2021.1.1(大黄蜂版本)的使用方法和相关知识,包括Gradle的介绍、设备管理器的配置、无线调试、新版本问题等内容。同时还提供了更新版本的下载地址和启动页面截图。 ... [详细]
  • 本文介绍了P1651题目的描述和要求,以及计算能搭建的塔的最大高度的方法。通过动态规划和状压技术,将问题转化为求解差值的问题,并定义了相应的状态。最终得出了计算最大高度的解法。 ... [详细]
  • XML介绍与使用的概述及标签规则
    本文介绍了XML的基本概念和用途,包括XML的可扩展性和标签的自定义特性。同时还详细解释了XML标签的规则,包括标签的尖括号和合法标识符的组成,标签必须成对出现的原则以及特殊标签的使用方法。通过本文的阅读,读者可以对XML的基本知识有一个全面的了解。 ... [详细]
  • CF:3D City Model(小思维)问题解析和代码实现
    本文通过解析CF:3D City Model问题,介绍了问题的背景和要求,并给出了相应的代码实现。该问题涉及到在一个矩形的网格上建造城市的情景,每个网格单元可以作为建筑的基础,建筑由多个立方体叠加而成。文章详细讲解了问题的解决思路,并给出了相应的代码实现供读者参考。 ... [详细]
  • IOS开发之短信发送与拨打电话的方法详解
    本文详细介绍了在IOS开发中实现短信发送和拨打电话的两种方式,一种是使用系统底层发送,虽然无法自定义短信内容和返回原应用,但是简单方便;另一种是使用第三方框架发送,需要导入MessageUI头文件,并遵守MFMessageComposeViewControllerDelegate协议,可以实现自定义短信内容和返回原应用的功能。 ... [详细]
  • MVC设计模式的介绍和演化过程
    本文介绍了MVC设计模式的基本概念和原理,以及在实际项目中的演化过程。通过分离视图、模型和控制器,实现了代码的解耦和重用,提高了项目的可维护性和可扩展性。详细讲解了分离视图、分离模型和分离控制器的具体步骤和规则,以及它们在项目中的应用。同时,还介绍了基础模型的封装和控制器的命名规则。该文章适合对MVC设计模式感兴趣的读者阅读和学习。 ... [详细]
  • Todayatworksomeonetriedtoconvincemethat:今天在工作中有人试图说服我:{$obj->getTableInfo()}isfine ... [详细]
  • Asp.net Mvc Framework 七 (Filter及其执行顺序) 的应用示例
    本文介绍了在Asp.net Mvc中应用Filter功能进行登录判断、用户权限控制、输出缓存、防盗链、防蜘蛛、本地化设置等操作的示例,并解释了Filter的执行顺序。通过示例代码,详细说明了如何使用Filter来实现这些功能。 ... [详细]
  • 本文介绍了ASP.NET Core MVC的入门及基础使用教程,根据微软的文档学习,建议阅读英文文档以便更好理解,微软的工具化使用方便且开发速度快。通过vs2017新建项目,可以创建一个基础的ASP.NET网站,也可以实现动态网站开发。ASP.NET MVC框架及其工具简化了开发过程,包括建立业务的数据模型和控制器等步骤。 ... [详细]
author-avatar
肥妹---君
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有