Go语言怎么做六边形架构_Go语言六边形架构教程【简明】

六边形架构在Go中核心是划清三道依赖线:领域层禁用适配器、端口接口须定义在domain或infra、DI入口必须位于adapter层;目录隔离重于结构模板,gRPC需作为驱动适配器而非领域延伸,Wire需严查指针返回与显式绑定。六边形架构在 Go 里不是"搭架子",而是划清三道线Go 项目用六边形架构,核心不是目录建得多整齐,而是靠三道不可逾越的依赖线把业务逻辑护住:领域层 不能 import 任何适配器(比如 github.com/go-sqlite/sqlite3、google.golang.org/grpc)、端口接口必须定义在领域层或 infra 层(不能藏在 adapter/repository 里)、Wire 或其他 DI 工具的 inject.go 文件必须落在适配器层------这是唯一能同时看到领域接口和具体实现的地方。常见错误现象:domain/order_service.go 直接 import "gorm.io/gorm",后续加 Redis 缓存或换 PostgreSQL 就得改业务代码正确做法:在 domain/repository.go 定义 type OrderRepository interface { Save(ctx context.Context, o *Order) error },让 adapter/repository/mysql_order_repo.go 去实现它Wire 的 InitializeApp() 函数必须放在 cmd/ 或 adapter/server/ 下,否则生成的依赖图会绕过端口约束目录结构别硬套模板,先守住 domain/ 和 adapter/ 的物理隔离很多团队卡在第一步,是因为照抄 "domain/aggregate/entity" 这类子目录,结果把 po.Order(数据库表结构)和 domain.Order(含业务规则的实体)混在同一个包里,或者让 adapter/controller 直接 new 出 domain.OrderService ------ 这等于把六边形画成了实心圆。domain/ 下只放:聚合根(order.Aggregate)、值对象(money.Money)、领域服务接口(order.PaymentService)、DTO(order.CreateOrderRequest)adapter/ 下分两块:controller/(接收 HTTP 请求、校验、转成 domain.DTO)、repository/(实现 domain.Repository 接口,用 SQL 或 gRPC 调用外部服务)infra/ 是可选缓冲区:放 infra/db/sqlx_client.go、infra/mq/kafka_producer.go 等"纯技术组件",它们被 repository 适配器调用,但 domain 层完全看不见gRPC 服务怎么当好"驱动适配器",而不是入侵领域层gRPC 不是领域模型的延伸,它是外部系统驱动你业务的一条通道。把它当"HTTP 的替代品"来用,就很容易把 proto 文件里的 message 直接当 domain 实体用,导致领域逻辑被 protobuf 序列化规则绑架。 Mokker AI AI产品图添加背景

相关推荐
NiceCloud喜云1 小时前
Opus 4.8 的 Effort Control 怎么选:Low 到 Max 五档策略
android·java·大数据·前端·c++·python·spring
ccddsdsdfsdf1 小时前
DBeaver怎么链接mongoDB
数据库·mongodb
AI玫瑰助手1 小时前
Python函数:默认参数的定义与注意事项
开发语言·python·信息可视化
weixin_468466851 小时前
全局与局部注意力机制新手实战指南
人工智能·python·深度学习·算法·自然语言处理·transformer·注意力机制
小糖学代码2 小时前
LLM系列:环境搭建:5.Python-dotenv 环境变量管理
人工智能·python·深度学习·神经网络
丷丩2 小时前
Postgresql基础实践教程(十一)各种Join
数据库·postgresql·join
星夜夏空992 小时前
FreeRTOS学习(4)——内存映射
数据库·学习·mongodb
智慧物业老杨2 小时前
智慧物业合同周期管理系统:从风险预警到智能交接的全流程数智化落地方案
java·人工智能·python
橙橙笔记3 小时前
Python的学习第一部分
python·学习
TheRouter3 小时前
AI Agent 记忆体系建设实战:短期、长期与工作记忆的工程实现
数据库·人工智能·oracle