同步网盘实现托管私人Git项目

需求

我有一个早前一人开发的源代码项目,现在想对其进行版本跟踪,用Git,我该怎么做?
这个需求是很直观的,它忽略了一些潜在需求和前提。第一,我的项目可能要有多人来协作开发;第二,私有项目,我不便使用公共托管空间(像github),但也不想花钱买私有的,毕竟只是很小的项目;另外免费的私有空间容易不稳定(被墙或倒闭),例如 Bitbucket.org。

起点

网上简单搜索下,发现《巧用网盘托管私人Git项目》(http://www.cnblogs.com/craftor/archive/2012/11/04/2754193.html)这篇文章基本够用,但是它的表述不够清楚和详细,对于初学Git的人来说有一点费解。盲目照着做也能基本满足需要,但是初学者可能只能停留在一知半解。本文在《巧用》一文的基础上,总结利用「坚果云」提供的免费同步网盘实现托管私人Git项目。

知识

Git提供了大量操作命令,这对很多人来说是一个坎(个人认为,Git的设计过于灵活了,以致于其学习曲线异常的陡峭)。但是,如果我们了解「版本控制事务」的一些实质,对这些命令进行分类后,会比较容易迈过这个坎。我们要对一个「项目数据」的版本仓库进行跟踪控制,第一件事是「创建和配置这个仓库」,接着才是对其进行「实际跟踪和控制」。我们称第一种为元操作(meta op),后一种为体操作(body op)。如下图:

同步网盘实现托管私人Git项目_第1张图片

在这个概念图里,我们特别关注三个中心概念:repo, branch, commit。它们都是我们版本仓库跟踪控制的实际目标,只是「数据粒度」不同,它们有各自的「体操作」和「元操作」。commit是真正的版本,branch是版本序列(线性历史),repo是版本历史树。另外,在 repo 的体操作事务里,我们将一些查看仓库状态的操作划出一小类,称为前体操作(pre body op)。

由于Git是一种分布式控制工具,它为传统的集中式版本控制引入一些新的概念和事务,这是需要特别注意的。以下罗列一些重要的概念:

  • 第一,分布式的版本仓库「不是一个库」,而是多个(实例),所以当我们创建新库时,是在创建一个仓库系统(由多个仓库实例组成),所以有clone创建事务;
  • 第二,由于有多个相同仓库实例,并且有本地与远程的概念,所以版本仓库「天生有remote属性」,所以有remote配置事务;
  • 第三,由于团队每人都拥有一个完整的仓库,故Git没有明显的签出(Checkout)单个文件的概念;
  • 第四,由于有多个相同仓库实例,故Git有一个同步多个实例的配置事务,所以有fetch, push 和 pull 等事务;
  • 第五,在「源码项目」内的.git 目录就是(本地)版本仓库实例所在,「源码项目」目录数据(.git 目录以外)就是working copy;远程库(尤其是中心库)没有(也不需要)working copy,这就是「创建远程库」的–bare参数的意义;
  • 第六,Git有一个位于working copy和仓库之间的「变更暂存区(stage
    area)」,叫index,故在正式提交新版本之前有一个 git add操作——将多次变更累积在一起;

思路

使用同步网盘实现托管私人Git项目(多人异地项目版本控制)的基本思路是:
1在本地机器分别创建「本地仓库」和「“远程”仓库」;
2
再将本地仓库的「远程库属性(用git remote)」指向为本地这个「假远程仓库」;
3将假“远程”仓库的数据目录用同步盘实现网络同步;
4
团队其他人在自己的机器上配置同步盘;
5` 再从这个盘上的假远程仓库复制(git clone)一个本地仓库实例;

实现

假设我们的项目叫myproject,保存本地文件目录(~/myproject_local),将假远程仓库保存在 (~/net.syc.dir/myproject_remote),对照思路,我们的具体实现如下:

1.1 创建 “远程”仓库

$ mkdir ~/net.syc.dir/myproject_remote
$ cd ~/net.syc.dir/myproject_remote
$ git --bare init

1.2 创建本地仓库,并用已有的working copy进行初始化

$ cd ~/myproject_local
$ git init
$ git add .  
$ git commit –m “commit”

注意:在add 到index之前,编写.gitignore文件,过滤掉不需要版本跟踪的数据

2.1 配置本地仓库的远程库属性

$ cd ~/myproject_local
$ git remote add origin ~/net.syc.dir/myproject_remote master

2.2 同步两个仓库实例,完整构建一个 Git版本控制系统

$ git push origin master

3. 配置同步盘

安装好同步网盘客户端后,将“远程”仓库的目录~/net.syc.dir/myproject_remote添加同步任务即可,细节略

4.细节略

5.细节略

你可能感兴趣的:(同步网盘实现托管私人Git项目)