golang-standards 提供的golang 项目结构布局

golang-standards 社区提供了一个golang 项目的参考结构,同时提供了比较完整的说明

go 目录

  • /cmd 
    项目的主干,次目录应该足够简单
  • /interenal 
    内部的,不需要分享到外部的,这个属于golang 内部的一个特性,我们也会在好多开源项目中看到
  • /pkg 
    可复用的一些代码库
  • /vendor 
    vendor 模式的包,现在推荐的玩法是go modules 功能

服务应用模式

  • /api 
    关于openapi/swaggeer 规范的json 模式文件

web 应用模式

  • /web 
    静态web资源,服务器模版以及单页面应用。。。

通用应用

  • /config 
    配置文件模版或者more 嗯配置
  • /init 
    system init 管理的脚本
  • /scripts 
    构建,安装,分析等的脚本
  • /build 
    打包以及持续集成的
  • /deployments 
    关于iaas paas,以及部署的,也可以水用/deploy 命名
  • /test 
    关于程序测试的

其他目录

  • /docs 
    设计以及用户文档
  • /tools 
    项目的支持工具,工具可以从/pkg 以及/inteernal 导入
  • /examples 
    公共实例
  • /thrid_party 
    外部辅助工具和,或者其他三方工具
  • /githooks 
    git hooks
  • /assets 
    与代码库共享的(图像,徽标)
  • /websitee 
    关于项目的website 文档,可以使用github pages 。。。

不应该用的目录

  • /src 
    以前好多项目使用的是src 模式,已经不推荐使用了

参考资料

https://github.com/golang-standards/project-layout 
https://github.com/danceyoung/paper-code/blob/master/package-oriented-design/packageorienteddesign.md

posted on   荣锋亮  阅读(784)  评论(0编辑  收藏  举报

编辑推荐:
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
阅读排行:
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· .NET10 - 预览版1新功能体验(一)
历史上的今天:
2019-09-10 fpm 打包跨平台rpm 包的一个问题
2019-09-10 使用jpillora/dnsmasq 提供可视化管理的dns server
2018-09-10 grandstack graphql 工具基本试用
2018-09-10 grandstack 基于graphql&&react&& apollo&& neo4j 的全栈开发工具

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5
点击右上角即可分享
微信分享提示