六边形架构 Java 实现

六边形架构是一种设计风格,经过分层实现核心逻辑与外部对象隔离。其核心逻辑是业务模块,外部元素是整合点,好比数据库、外部 API、界面等。它将软件分为内部与外部,内部包含了核心业务逻辑与领域层(所谓分层架构),外部包含界面、数据库、消息传递及其余内容。内部与外部经过端口和适配器相互通讯。java


*译注:六边形架构(Hexagonal Architecture)由Alistair Cockburn 提出,解决了传统的分层架构所带来的问题。*git


1. 优势github


  • 使用六边形架构开发的软件与通道独立,所以能支持多通道数据库

  • 易于置换入站和出站整合点架构

  • 测试软件变得更简单,由于能够很容易地模拟集成点app


2. Java 实现ide


按照上面的描述,六边形架构更多地是围绕端口和适配器开展工做。在 Java 中,用 interface 定义端口,实现类做为适配器。下面用一个简单的 Spring Boot 应用示例了解如何应用六边形架构。测试


示例应用主要功能是建立并查看雇员信息,核心业务逻辑在 `EmployeeService` 中实现,领域对象定义为 `Employee` ,这些均可以看作内部模块。spa


**EmployeeService.java**

```java
@Service
public class EmployeeService {
   @Autowired
   private EmployeeRepositoryPort employeeRepository;

   public void create(String name, String role, long salary){
       employeeRepository.create(name, role, salary);
   }
   
   public Employee view(Integer userId){
       return employeeRepository.getEmployee(userId);
   }
}
```


**Employee.java**

```java
@Entity
@Table(name = "employee")
public class Employee{
   @Id
   @GeneratedValue
   @Column(name = "id")
   private Integer id;

   @Column(name = "name", nullable = false)
   private String name;

   @Column(name = "role", nullable = false)
   private String role;

   @Column(name = "salary", nullable = false)
   private long salary;
   // Setter、Getter 方法
}
```


如今,示例应用能够经过 REST 或消息机制提供服务。建立实现了`EmployeeUIPort` 接口的 `EmployeeControllerAdapter` 类提供 REST 服务。设计


**EmployeeControllerAdapter.java**

```java
RestController
@RequestMapping("/employees/")
public class EmployeeControllerAdapter implements EmployeeUIPort{
   @Autowired
   private EmployeeService employeeService;

   @Override
   public void create(@RequestBody Employee request)
{
       employeeService.create(request.getName(), request.getRole(), request.getSalary());
   }

   @Override
   public Employee view(@PathVariable Integer id)
{
       Employee employee = employeeService.view(id);
       return employee;
   }
}
```


```java
public interface EmployeeUIPort {
   @PostMapping("create")
   public void create(@RequestBody Employee request);

   @GetMapping("view/{id}")
   public Employee view(@PathVariable Integer userId);
}
```


做为业务逻辑的一部分,`EmployeeService` 还须要调用外部 DB 集成点。所以,咱们建立了 `EmployeeRepositoryPort` 以及实现了该接口的`EmployeeServiceAdapter`


**EmployeeServiceAdapter.java**

```java
@Service
public class EmployeeServiceAdapter implements EmployeeRepositoryPort {
   @PersistenceContext
   private EntityManager entityManager;

   @Transactional
   @Override
   public void create(String name, String role, long salary)
{
       Employee employee = new Employee();
       employee.setName(name);
       employee.setRole(role);
       employee.setSalary(salary);
       entityManager.persist(employee);
   }

   @Override
   public Employee getEmployee(Integer userId)
{
       return entityManager.find(Employee.class, userId);
   }
}
```


**EmployeeRepositoryPort.java**

```java
public interface EmployeeRepositoryPort {
   void create(String name, String role, long salary);

   Employee getEmployee(Integer userId);
}
```


至此,咱们能够看到 `EmployeeService` 是如何使用 `EmployeeUIPort` 端口提供服务,经过 `EmployeeRepositoryPort` 调用 DB 并经过 `EmployeeControllerAdapter`和 `EmployeeServiceAdapter` 提供 REST API 服务。


3. 总结


总结一下,六边形架构是一种将应用划分红内外两部分的设计方法。经过内部公开的端口与外部实现的适配器进行沟通。应用这种方法,在保持核心用例代码不变的状况下,能够服务多个通道、支持多种不一样协议。 不只如此,它还能有效提升应用程序的可测性。尽管如此,不建议在整个应用中彻底实现六边形架构,而是有选择地使用接口与适配器。


示例代码可在 [GitHub][1] 中找到。


[1]:https://github.com/RajeshBhojwani/hexagonal.git

相关文章
相关标签/搜索