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

Hexagonal architecture

Hexagonal architecture (http://alistair.cockburn.us/Hexagonal+architecture), also known as the ports and adapters pattern, aims to decouple business logic from other parts of the component, especially the persistence and services layers. A component, built on the ports and adapters pattern, exposes a set of ports to which one or more adapters can be added as necessary. For example, to test and verify the core business logic in isolation, a mock database adapter can be plugged in and later replaced with a runtime database adapter in production.

A port is an entry point that is provided by the core business logic to interact with other parts of the component. An adapter is an implementation of a port, and there may be more than one adapter defined for a single port based on the requirement. For example, a REST adapter is used to accept requests from external users or other microservices components. It internally calls the service API port defined by the core business logic that performs that requested operation and generates a response. Similarly, a database adapter is used by the core business logic to interact with the external database via its database port, as shown in the following diagram:

Based on their applicability and usage, the REST adapter and database adapter are often referred to as primary and secondary adapters respectively. Similarly, the service API port and database port are referred to as primary and secondary ports respectively. Primary ports are called by the primary adapters and they act as the main interface between the core business logic and its users, whereas secondary ports and secondary adapters are used by the core business logic to generate events or interact with external services, like a database. Primary adapters help validate service requests with respect to a service schema and call core business logic functions, whereas the core business logic calls the functions of secondary adapters to help translate the application schema to the external service schema, like that of a database. Primary adapters are initialized with the application, but references to the secondary adapters are passed to the core business logic via dependency injection.

The name hexagonal architecture is derived from the structure of a component that has six ports, but that is not a rule. The idea of representing the architecture as a hexagon is just to remove the notion of one-dimensional layered architecture and have room to insert ports and adapters as required.
主站蜘蛛池模板: 天镇县| 杭锦后旗| 吴江市| 华容县| 南丰县| 北海市| 丹巴县| 齐齐哈尔市| 贵定县| 定南县| 嘉义县| 天气| 成安县| 鲁甸县| 普格县| 托里县| 晋江市| 沅陵县| 宣恩县| 出国| 磴口县| 黄石市| 乡城县| 曲麻莱县| 象山县| 金乡县| 陆河县| 邛崃市| 邵东县| 清新县| 娄底市| 庐江县| 临朐县| 堆龙德庆县| 米脂县| 囊谦县| 剑河县| 永川市| 加查县| 正安县| 安庆市|