13

我是一个正在启动的项目的一部分,该项目将具有一个客户端可执行文件和一个服务器可执行文件。我们正在使用 git 来帮助我们的团队更新代码,这对于我们许多人来说是第一次使用 git(这个项目是针对一个班级的)。我开始为我的项目设置 git 存储库以供使用,但我不确定拥有客户端和服务器代码的最佳设计是什么。

那么问题来了,应该如何设置存储库?两者之间不会有太多的代码共享,除了网络。然而,我们将两者之间的网络视为最重要的方面,并希望保持两者使用相同的网络概念。我已经对顶部进行了一些研究,我看到了可能性,两个独立的存储库,我们必须确保两个代码相互兼容,还是我们使用单个存储库?

对于这种相当新的方法,我感到很抱歉,我已经阅读了“Git Pro”,但还没有太多使用 git 与多人合作的项目的经验。

4

2 回答 2

7

如果客户端和服务器彼此相当独立,那么它们很适合放在自己的 git 存储库中。这就是组件方法

你可以有三个回购:

  • 客户
  • 服务器
  • 网络(通用模块)

Git 中的submobules可以很好地记录您在系统中一起使用的确切 SHA1。
所以你可以定义2个父母回购:

  • 客户端应用

    • 客户
    • 联网
  • 服务器应用

    • 服务器
    • 联网

这个想法是能够说明客户端和服务器是否使用相同或不同版本的网络。

对于一个类项目来说,所有设置可能是一种过度杀伤,但可以说明系统方法(一个巨大的 repo 中的所有内容)和组件方法之间的区别。

在不同的 git repo 中分离允许独立的标记和分支。

于 2013-02-06T20:15:41.633 回答
0

您应该使用单个存储库,因为它可以包含多个项目/解决方案/构建可执行文件的任何其他内容。

一般来说,我会按照您希望在本地组织它的方式来组织它。没有理由偏离对你有用的方法来适应 git。

我建议建立一个各方都可以访问的github存储库。

于 2013-02-06T20:10:00.993 回答