04-基于DDD的开发架构阐述.pdfVIP

  1. 1、本文档共15页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
04-基于DDD的开发架构阐述

基于DDD的开发架构阐述 Presented by 陈操 chencao0524@ 红帽中国 4/2010 1 © Red Hat, Inc. 2010 提纲 背景和面临的问题 • 传统的设计方式和开发框架及其问题 • 传统坏设计之一——贫血模型 • 传统坏设计之二——基于数据表的设计 • 总结:企业业务信息化所面临的问题 Redhat解决方案 • 思想理论:基于领域驱动设计(Domain-Driven Design) • 技术实现:使业务仅仅只依赖JDK和一些通用包,而不依赖于 其他开发框架 2 传统的设计方式和开发框架及其问题 • 传统设计的分层结构  Model层 • model层中的对象被建模成业务对象,但仅仅只包含业务对象的属性,比如Employee对象有name,birthday 属性,但不包含这个对象的业务方法和行为。 • 论述:对于面向对象的思想而言,model层中的对象并不完整和丰满,因为对象中除了基本属性以外没有对应 的行为。对比于JDK 中Date对象有compareTo()方法,因此,传统model层中的对象被称之为“贫血模型”。  Dao层 • Dao层处理与底层数据库的交互。  Service层 • 公开服务供外部调用。 • 论述:此处是业务逻辑和应用逻辑混杂的地方。  展现层 • 使用各种页面框架:如Struts、Tapestry、SpringMVC等。 • 流行的开发框架  Spring  Struts  Hibernate  Tapestry  论述:系统构建在以上框架之上,不少业务逻辑依赖于框架代码。这样,框架代码侵入业务逻辑,会造成 业务逻辑与框架代码的耦合,不利于业务逻辑的独立和企业未来技术路线的变更 3 传统的设计方式和开发框架及其问题 由于设计或编码 核心业务逻辑 展现层 危险! 不当,“核心业 务逻辑”容易散 布在各处: 核心业务逻辑和 Service层 应用逻辑混杂 Model层 核心业务逻辑 Dao层 危险! DataBase 4 传统坏设计之一——贫血模型 • 传统的分层结构  业务逻辑和应用逻辑并没有被有效区分,大部分业务逻辑写在控制器Controller中,比如 Strtus的Action ;业务逻辑和应用逻辑充斥在各个层次中,十分混乱。 • SOA  对于SOA服务,大部分业务逻辑写在Service中。  如果太过强调SOA服务,忽略了领域模型的重要性,最终将得到一个贫血的领域模型和臃 肿的服务。  如果后端却没有一个像样的领域模型,业务服务就会调用不完整的领域模型,这可能会导 致出现一个脆弱的SOA架构。 • 贫血模型  以上两种设计,Model是只有getter/setter方法的贫血模型,仅仅成为一个数据载体,没有

文档评论(0)

xcs88858 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

版权声明书
用户编号:8130065136000003

1亿VIP精品文档

相关文档