繁体   English   中英

带有git子模块的Docker项目结构

[英]Docker project structure with git submodules

当我看到使用Docker的git项目时,则将docker仅添加到git项目中,该项目包含一个应用程序的源代码。 但是如果我想使用docker-compose来组织多个git项目,因为它们可以协同工作(后端,前端等),该怎么办?

现在,我使用来自其他两个git项目的源代码以及一些其他自行创建的Dockerfile-因此,我的compose-file现在具有7个服务(还有来自docker hub的一些公共服务)。 我还需要为不同的用例(只是具有不同的环境变量)创建略有不同的.yml文件。 是否有最佳实践来组织这样的项目?

我的项目如下所示:

my-project/
|__ env/
|   |__ service-1/
|   |   |__ default.env
|   |   |__ usecase-1.env
|   |__ service-2/
|       |__ default.env
|       |__ usecase-1.env
|__ override/
|   |__ usecase-1.yml
|__ src/
|   |__ service-1/
|   |   |__ service-1/ (git submodule)
|   |   |__ Dockerfile
|   |__ service-2/
|       |__ Dockerfile
|__docker-compose.yml # default .yml, containing service-1 and service-2

因此,如果有一个新的用例,我将在override /中创建一个新usecase-2.yml并在env /文件夹中创建一些新usecase-2.env文件。

就我自己而言,这是合乎逻辑的,但是我不知道最佳实践是什么-因为我找不到任何类似的项目。

如果要使用git子模块 ,则需要按服务而不是envsrc进行分组:

my-project/
|__ service-1/
|   |__ env/
|   |__ src/
|   |__ Dockerfile
|__ override/
|   |__ usecase-1.yml
|__ service-2/
|   |__ env/
|   |__ src/
|   |__ Dockerfile
|__docker-compose.yml # default .yml, containing service-1 and service-2

这样, service-1service-2可以是它们自己的git repos,可以将其添加为主父存储库“ my-project ”中的子模块。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM