官术网_书友最值得收藏!

Understanding SoA

Microservices are an evolution of the Service Oriented Architecture (SoA). So, if we want to understand what a microservice is, we need to understand what SoA is. SoA is based on having application components communicating through a set of services, a discrete unit of functionality that can be accessed remotely. Services are the foundation stone in SoA, and the same applies to microservices as well.

As described in SoA, a service has four properties:

  • It logically represents a business activity with a specified outcome
  • It is self-contained
  • It is a black box for its consumers
  • It may consist of other underlying services

To understand these properties, let's look at an example of an application using SoA:

SoA application example

In this typical n-tier architecture, the application is divided into three layers:

  • Presentation layer: Holds the UI for our customer
  • Business layer: Has services implementing the domain logic for our business capabilities
  • Data layer: Persists our domain model

Each component includes the logic to interact with the customer in a specific business activity and to do so, uses the services provided by the business layer. Each service represents the realization of a business activity. For example, you log in to the application provided by the login service, check offers provided by the offers service or create orders via the orders service. These services are self-contained in the business layer, and they act as a black box for their consumer—the components don't know how the services are implemented, nor do they know how the domain model is persisted. All the services depend on the customer service to obtain customer data, or return customer information, but the client does not know about these details.

This approach provides several benefits to any architecture that uses it:

  • Standardized service contract, allowing easy integration with components
  • Reusability, allowing services to delegate responsibilities to each other
  • Business value, implementing the business capabilities
  • Hides complexity; if we need to change our database, the clients are unaffected
  • Autonomyl; each of the layers could be separated and be accessed remotely
主站蜘蛛池模板: 桓仁| 娱乐| 滦平县| 日喀则市| 白银市| 丰宁| 富源县| 南乐县| 建昌县| 武安市| 通城县| 漳州市| 长宁区| 曲阳县| 镇雄县| 饶阳县| 师宗县| 霞浦县| 永胜县| 开鲁县| 张家界市| 萝北县| 宣汉县| 当涂县| 清河县| 从江县| 西藏| 高邮市| 海盐县| 禹州市| 沈丘县| 新建县| 东阿县| 建水县| 深泽县| 奉贤区| 武平县| 浮梁县| 营口市| 武川县| 巨野县|