模式:通过业务能力上下文分解

Pattern: Decompose by business capability Context

You are developing a large, complex application and want to use the microservice architecture. The microservice architecture structures an application as a set of loosely coupled services. The goal of the microservice architecture is to accelerate software development by enabling continuous delivery/deployment.

The microservice architecture does this in two ways:

  1. Simplifies testing and enables components to deployed independently
  2. Structures the engineering organization as a collection of small (6-10 members), autonomous teams, each of which is responsible for one or more services

These benefits are not automatically guaranteed. Instead, they can only be achieved by the careful functional decomposition of the application into services.

A service must be small enough to be developed by a small team and to be easily tested. A useful guideline from object-oriented design (OOD) is the Single Responsibility Principle (SRP). The SRP defines a responsibility of a class as a reason to change, and states that a class should only have one reason to change. It make sense to apply the SRP to service design as well and design services that are cohesive and implement a small set of strongly related functions.

The application also be decomposed in a way so that most new and changed requirements only affect a single service. That is because changes that affect multiple services requires coordination across multiple teams, which slows down development. Another useful principle from OOD is the Common Closure Principle (CCP), which states that classes that change for the same reason should be in the same package. Perhaps, for instance, two classes implement different aspects of the same business rule. The goal is that when that business rule changes developers, only need to change code in a small number – ideally only one – of packages. This kind of thinking makes sense when designing services since it will help ensure that each change should impact only one service.

Problem

How to decompose an application into services?

Forces

  • The architecture must be stable
  • Services must be cohesive. A service should implement a small set of strongly related functions.
  • Services must conform to the Common Closure Principle – things that change together should be packaged together – to ensure that each change affect only one service
  • Services must be loosely coupled – each service as an API that encapsulates its implementation. The implementation can be changed without affecting clients
  • A service should be testable
  • Each service be small enough to be developed by a “two pizza” team, i.e. a team of 6-10 people
  • Each team that owns one or more services must be autonomous. A team must be able to develop and deploy their services with minimal collaboration with other teams.

Solution

Define services corresponding to business capabilities. A business capability is a concept from business architecture modeling. It is something that a business does in order to generate value. A business capability often corresponds to a business object, e.g.

  • Order Management is responsible for orders
  • Customer Management is responsible for customers

Business capabilities are often organized into a multi-level hierarchy. For example, an enterprise application might have top-level categories such as Product/Service developmentProduct/Service deliveryDemand generation, etc.

Examples

The business capabilities of an online store include:

  • Product catalog management
  • Inventory management
  • Order management
  • Delivery management

The corresponding microservice architecture would have services corresponding to each of these capabilities.

Resulting Context

This pattern has the following benefits:

  • Stable architecture since the business capabilities are relatively stable
  • Development teams are cross-functional, autonomous, and organized around delivering business value rather than technical features
  • Services are cohesive and loosely coupled

Issues

There are the following issues to address:

  • How to identify business capabilities? Identifying business capabilities and hence services requires an understanding of the business. An organization’s business capabilities are identified by analyzing the organization’s purpose, structure, business processes, and areas of expertise. Bounded contexts are best identified using an iterative process. Good starting points for identifying business capabilities are:
    • organization structure – different groups within an organization might correspond to business capabilities or business capability groups.
    • high-level domain model – business capabilities often correspond to domain objects
摘自《BangEA实践公开课》讲义
摘自《BangEA实践公开课》讲义

转:https://microservices.io/patterns/decomposition/decompose-by-business-capability.html

更多文章

业务架构学习群资料

D4.1 对齐业务架构和规模化敏捷框架

当今的商业环境要求做出正确的决策和快速的跟进,以应对全球竞争和快速的市场破坏。作为回应,越来越多的组织寻求行之有效的框架来实现敏捷性,使它们能够保持竞争力和创新性。为了实现这些目标,人们对业务架构和使用规模化敏捷技术(如SAFe®等)协调不同敏捷团队的能力产生了越来越多的兴趣。

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

D2.1 价值流和业务流程:业务架构视角

业务架构价值流和相关能力提供了一种基于价值的视角,以运营任何类型的业务(如任何酒店)所需的能力,而不考虑组织结构、位置、产品变体、特定过程,或其他区分特定业务或业务链的运营特征。相比之下,基于价值的业务流程及其作为活动和流的分解,提供了一个基于价值的视角,通过一个(可能是通用的)业务活动实现商品、信息和成果的实现。

阅读更多»