内外六边形
将应用分为内六边形和外六边形两层
内六边形实现应用的核心业务逻辑
外六边形完成外部应用、基础资源等的交互和访问。
对于与不同的外部系统交互,由外六边形的适配器负责协议转换,保证内六边形业务逻辑的干净。
理论备注
分层架构一旦使用依赖倒置、依赖注入的方式,便不属于分层架构,自然就拥有了端口与适配器风格。各个组件的交互完全通过接口完成,而不是具体细节。无论是高层还是底层,都依赖于抽象(因抽象接口都定义在了领域层,看起来领域层已经成为了中心,层次架构已经是内外结构)
在六边形架构中,每条边要么代表客户输入交互的不同端口,通过不同类型的适配器进行适配完成格式协议转换等,从而实现程序内部可理解的输入类型;要么代表通过不同的适配器输出存储实例、向外界发送时间消息等输出类型
六边形架构中的内部六边形代表了应用程序,是一个应用程序的边界。应当根据应用程序的功能需求提供给外部适配器使用,要求使用领域模型来处理请求,并包含业务实现功能。这里我们可以看出,外部适配器可能存在无数个,但应用程序的个数是确定的且是根据业务需求决定的,提倡业务逻辑为关注点(六边形的核心),其余都是可替换的。外部都是可替换的