分享
  1. 首页
  2. 文章

golang领域模型-六边形架构

八叉树 · · 3675 次点击 · · 开始浏览
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

困惑:

  • 在分层架构中是否困惑过某些逻辑处理或某些数据处理该放在哪一层?
  • 在分层架构中是否困惑过该分多少层?
  • 在分层架构中是否困惑过平层和跨层调用是否合理?

六边形架构

Alistair Cockburn 提出了一种具有对称特征的架构风格。在这种架构中,不同的客户通过平等的方式与系统交互。比如HTTP客户,MQ客户,它们平等对系统提供输入。Redis和DB也平等的提供输出。每个客户都拥有自己的适配器,去理解输入,比如gin、iris、echo就是http的适配器。那么内部是业务系统(领域模型),外部就是输入和输出的适配器。重心放在内部业务逻辑上,隔离输入和输出。如果非要用分层来理解,那么六边形分为内层和外层。

Alistair Cockburn提出的六边形是有Application和Domain的,但现在微服务体系下Application已经没有存在的必要了,一个微服务就是一个Application。落地的六边形图如下。

那么六边形和DDD的结合是如何应对上述困惑的。所有数据处理全部由repository 适配成实体,逻辑都是领域服务、聚合、实体的行为。分多少层和平层、跨层调用本身也不存在。

项目目录

  • domain - 领域模型
    • aggregate - 聚合
    • entity - 实体
    • *.go - 领域服务
  • adapter - 端口适配器
    • controller - 输入适配器
    • repository - 输出适配器
    • dto - 传输对象
    • po - 持久化对象
  • server - 服务端程序入口
    • conf - 配置文件
    • main.go - 主函数
  • infra - 基础设施
    • *go - 基础设施组件

domain 领域模型目录

对应六边形的内部,主要放领域服务service的代码。子目录分为aggregate聚合根目录、entity实体目录。

adapter 适配器目录

对应六边形的外部,主要是输入和输出的适配器。controller子目录负责 http的api输入,repository子目录负责实体的读写。dto子目录是controller或repository的外部输入输出对象。po子目录是数据库的持久化对象,这些对象是生成的。

代码示例

package controller
import (
 domain "github.com/8treenet/freedom/example/fshop/domain"
)
type Cart struct {
 Worker freedom.Worker
 CartSev *domain.Cart //购物车领域服务
}
// GetItems 获取购物车商品列表, GET: /cart/items route.
func (c *Cart) GetItems() freedom.Result {
 userId, err := c.Worker.IrisContext().URLParamInt("userId")
 if err != nil {
 return &infra.JSONResponse{Error: err}
 }
 //适配http的输入参数userId后调用领域模型目录的入口领域服务
 dto, err := c.CartSev.Items(userId)
 if err != nil {
 return &infra.JSONResponse{Error: err}
 }
 return &infra.JSONResponse{Object: dto}
}
package domain
import (
 //引用仓库
 "github.com/8treenet/freedom/example/fshop/adapter/repository"
 "github.com/8treenet/freedom/example/fshop/domain/aggregate"
)
// Cart 购物车领域服务.
type Cart struct {
 CartRepo repository.CartRepo //购物车仓库,这里是依赖注入的
}
// Items 购物车全部商品项
func (c *Cart) Items(userId int) (items dto.CartItemRes, e error) {
 // 使用 c.CartRepo读取购物车数据
 return
}
// DeleteAll 清空购物车
func (c *Cart) DeleteAll(userId int) (e error) {
 return c.CartRepo.DeleteAll(userId)
}

有疑问加站长微信联系(非本文作者)

本文来自:简书

感谢作者:八叉树

查看原文:golang领域模型-六边形架构

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

关注微信
3675 次点击
暂无回复
添加一条新回复 (您需要 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传

用户登录

没有账号?注册
(追記) (追記ここまで)

今日阅读排行

    加载中
(追記) (追記ここまで)

一周阅读排行

    加载中

关注我

  • 扫码关注领全套学习资料 关注微信公众号
  • 加入 QQ 群:
    • 192706294(已满)
    • 731990104(已满)
    • 798786647(已满)
    • 729884609(已满)
    • 977810755(已满)
    • 815126783(已满)
    • 812540095(已满)
    • 1006366459(已满)
    • 692541889

  • 关注微信公众号
  • 加入微信群:liuxiaoyan-s,备注入群
  • 也欢迎加入知识星球 Go粉丝们(免费)

给该专栏投稿 写篇新文章

每篇文章有总共有 5 次投稿机会

收入到我管理的专栏 新建专栏