应用架构原则

应用和系统架构代表了如何集成应用并识别使能和支持业务流程执行的业务系统的模型。

AA原则1:应用与领域模型一致

  • 声明:不管是定制还是购买,应用都是跨职能域团队创建的领域模型的产品,并受其影响。
  • 理由:在制定有效和灵活的解决方案决策时,应同时代表技术和商业利益。
  • 含义:
    • 领域驱动的设计将用于架构和构建符合业务需求的应用。
    • 架构设计先于应用设计和开发。

AA原则2:每个域模型代表一个独立的业务上下文

  • 声明:独立的上下文必然会保持独立性
  • 原理:有界上下文通过将它们分成单独的概念模块,提供了一种管理大型应用程序复杂性的方法。
  • 含义:
    • 每个有界上下文都可以自由选择其内部概念的名称,并且具有对其自己的持久性存储的独占访问权。
    • 应用程序不共享数据库。
    • 有界上下文与组件紧密映射。
    • 有界上下文的模型必须在内部是自洽的,但必须独立于其他上下文中的其他模型。
    • 每个有界上下文都在API介导的服务中实现并通过其访问。上下文之间的通信通过这些API进行。

AA原则3:实现受限业务上下文的组件通过已发布的公共接口和契约进行通信

  • 声明:组件不共享数据,除非通过API。
  • 理由:API提供了独立域进行通信和合作的方式。
  • 含义:
    • 组件是独立的,并针对特定的业务上下文而构建。
    • 组件不通过共享数据库共享数据。
    • 根据组件的需求,公共接口可能是RESTful,事件驱动,基于消息的,基于凭证或声明的API。
    • 组件必须努力保护其内部数据模型与其他组件的一致性。
    • 当组件在需要的地方谈论组件之间的组件时,为了提高灵活性和易理解性,首选使用诸如大学API这样的交换语言。

AA原则4:购买和开源解决方案优于自定义解决方案

  • 声明:只有在考虑其他来源和第三方替代方案的分析之后,才能做出构建自定义应用程序的决定。
  • 理由:在不考虑替代方案的情况下做出的决定可能是昂贵且难以支持的。没有理由重新发明已经存在的东西。
  • 含义:
    • 项目团队,架构师和系统工程师将在开发新技术之前考虑现有技术。
    • 还将考虑分析行业领先的第三方解决方案。
    • 在可能和可行的情况下,考虑“订购”而不是购买。
    • 总拥有成本应该是任何分析的一部分。
    • 购买或建造的决定应考虑上下文是大学使命的核心,支持大学使命还是通用。核心环境更有可能具有独特的业务价值并从定制解决方案中受益。

AA原则5:构建支持连续​​集成/连续交付方法的应用程序

  • 声明:持续交付支持安全,快速且可持续地将新功能,配置更改,错误修复以及实验投入生产或投入用户手中。
  • 基本原理:部署应该是常规且可预测的,以降低风险,降低成本并加快上市速度。
  • 含义:
    • 我们将购买、开发和使用工具来支持系统,配置和错误修复的部署。
    • 所有代码都将具有集成测试。
    • 监视系统将检测故障,并在必要时自动回滚部署。
    • 系统没有有限的更改窗口。这并不意味着产品或领域团队可能不会出于业务原因决定限制更改。

更多文章

业务架构学习群资料

D3.2 面向业务的服务导向基础

面向服务所体现的概念是在长期致力于模块化和分布复杂的计算机系统(反映和支持分布式商业世界的现实)的努力中演变而来的。然而,如今解决技术集成问题本身还不足以证明投资于面向服务的合理性。为了加强这一论点,人们对面向服务的业务敏捷性支持提出了各种各样的主张,因为在面向服务的环境中,通过组合服务、重新配置服务、重用服务等,解决方案更容易构建。也许,但是根据上面的面向服务的定义,许多企业在某种程度上已经实现了面向服务,但是仍然难以提供业务需要或期望的IT支持。因此,为了证明在面向服务方面的投资是合理的,我们需要使用新的架构原则来解决每个项目中出现的问题。

阅读更多»
业务架构学习群资料

W7.2 信息概念和治理

对于一个企业来说,拥有一个强有力的以业务为导向的信息概念定义是一个非常宝贵的里程碑。信息与业务能力的恰当对齐形成了强有力的信息治理程序的基础,信息治理反过来又为业务和技术项目提供了业务价值。本次分享将带我们了解BIZBOK指南中可操作的最佳实践,这将为您的业务架构实践提供行动、想法和见解。

阅读更多»