0

0

Golang初级项目中如何设计目录结构

P粉602998670

P粉602998670

发布时间:2026-01-08 01:55:29

|

352人浏览过

|

来源于php中文网

原创

Go项目应将main.go放在cmd/子目录下,如cmd/userapi/main.go;internal/为访问边界,仅父级可导入;pkg/仅放明确复用的通用组件;测试文件与被测文件同目录。

golang初级项目中如何设计目录结构

main.go 放哪?别塞进根目录

新手常把 main.go 直接丢在项目最外层,结果随着功能增加,根目录迅速堆满配置、工具脚本和测试文件。Go 官方推荐将入口文件放在 cmd/ 下,每个可执行程序一个子目录。比如项目叫 userapi,就建 cmd/userapi/main.go。这样既支持多命令(如 cmd/userapicmd/migrate),也避免 go build 时误编译非主包。

internal/ 不是摆设,是访问边界的硬约束

internal/ 目录下的包,只能被其父目录或祖先目录的代码导入——这是 Go 编译器强制的可见性规则。初级项目容易把所有业务逻辑塞进 pkg/ 或平铺在根下,导致后期模块耦合严重、无法安全重构。正确做法是:把核心业务逻辑(如用户认证、订单处理)放进 internal/userinternal/order;对外暴露的接口(如 HTTP handler、gRPC service)则放在 pkg/ 或直接由 cmd/ 调用。这样即使未来要抽成独立库,也能快速识别哪些代码能拆、哪些必须保留。

config/ 和 pkg/ 怎么分?看是否会被外部复用

pkg/ 应只放**明确设计为被其他项目复用**的通用能力,比如自定义日志封装 pkg/logger、统一错误码 pkg/errno。而项目专用的配置加载逻辑(如从 YAML 解析数据库地址、自动 fallback 环境变量)必须放在 internal/configcmd/userapi/config.go。常见错误是把 pkg/config 做成万能加载器,结果每次加个新字段都要改签名、发版本。实际中,80% 的配置解析只需在启动时调一次 viper.Unmarshal(),根本不需要抽象成包。

test 相关文件不要单独建 test/ 目录

Go 的测试惯例是:单元测试文件与被测文件同目录,文件名以 _test.go 结尾,比如 internal/user/service.go 对应 internal/user/service_test.go。不建议建顶层 test/ 目录集中放测试——那样会导致导入路径混乱(例如要写 import "myproj/test/mocks"),且 IDE 跳转、覆盖率统计都容易出错。集成测试若需独立数据或服务,可放在 internal/user/e2e_test.go,用 //go:build e2e 标签隔离。

名品购物网店系统
名品购物网店系统

适合品牌专卖店专用,从前台的美工设计就开始强调视觉形象,有助于提升商品的档次,打造网店品牌!后台及程序核心比较简洁,着重在线购物,去掉了繁琐的代码及垃圾程式,在结构上更适合一些中高档的时尚品牌商品展示. 率先引入语言包机制,可在1小时内制作出任何语言版本,程序所有应用文字皆引自LANG目录下的语言包文件,独特的套图更换功能,三级物品分类,购物车帖心设计,在国内率先将购物车与商品显示页面完美结合,完

下载

立即学习go语言免费学习笔记(深入)”;

myproj/
├── cmd/
│   └── userapi/
│       └── main.go
├── internal/
│   ├── config/          # 项目专用配置解析
│   ├── user/            # 用户领域逻辑(含 service_test.go)
│   └── order/
├── pkg/                 # 可被其他项目 import 的通用组件
│   └── logger/
├── go.mod
└── Dockerfile

真正难的是坚持——比如新增一个“通知”功能,本能想建 pkg/notify,但得先问:这个通知逻辑会不会被另一个项目(比如后台任务系统)直接 import?如果答案是否定的,它就该进 internal/notify。目录结构不是一开始画完就结束的事,而是每次加代码时都要做的判断。

相关专题

更多
golang如何定义变量
golang如何定义变量

golang定义变量的方法:1、声明变量并赋予初始值“var age int =值”;2、声明变量但不赋初始值“var age int”;3、使用短变量声明“age :=值”等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

177

2024.02.23

golang有哪些数据转换方法
golang有哪些数据转换方法

golang数据转换方法:1、类型转换操作符;2、类型断言;3、字符串和数字之间的转换;4、JSON序列化和反序列化;5、使用标准库进行数据转换;6、使用第三方库进行数据转换;7、自定义数据转换函数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

226

2024.02.23

golang常用库有哪些
golang常用库有哪些

golang常用库有:1、标准库;2、字符串处理库;3、网络库;4、加密库;5、压缩库;6、xml和json解析库;7、日期和时间库;8、数据库操作库;9、文件操作库;10、图像处理库。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

336

2024.02.23

golang和python的区别是什么
golang和python的区别是什么

golang和python的区别是:1、golang是一种编译型语言,而python是一种解释型语言;2、golang天生支持并发编程,而python对并发与并行的支持相对较弱等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

208

2024.03.05

golang是免费的吗
golang是免费的吗

golang是免费的。golang是google开发的一种静态强类型、编译型、并发型,并具有垃圾回收功能的开源编程语言,采用bsd开源协议。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

388

2024.05.21

golang结构体相关大全
golang结构体相关大全

本专题整合了golang结构体相关大全,想了解更多内容,请阅读专题下面的文章。

194

2025.06.09

golang相关判断方法
golang相关判断方法

本专题整合了golang相关判断方法,想了解更详细的相关内容,请阅读下面的文章。

189

2025.06.10

golang数组使用方法
golang数组使用方法

本专题整合了golang数组用法,想了解更多的相关内容,请阅读专题下面的文章。

191

2025.06.17

java学习网站推荐汇总
java学习网站推荐汇总

本专题整合了java学习网站相关内容,阅读专题下面的文章了解更多详细内容。

6

2026.01.08

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Go 教程
Go 教程

共32课时 | 3.5万人学习

Go语言实战之 GraphQL
Go语言实战之 GraphQL

共10课时 | 0.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号