需求
我有一个早前一人开发的源代码项目,现在想对其进行版本跟踪,用Git,我该怎么做?
这个需求是很直观的,它忽略了一些潜在需求和前提。第一,我的项目可能要有多人来协作开发;第二,私有项目,我不便使用公共托管空间(像github),但也不想花钱买私有的,毕竟只是很小的项目;另外免费的私有空间容易不稳定(被墙或倒闭),例如 Bitbucket.org。
起点
网上简单搜索下,发现《巧用网盘托管私人Git项目》(http://www.cnblogs.com/craftor/archive/2012/11/04/2754193.html)这篇文章基本够用,但是它的表述不够清楚和详细,对于初学Git的人来说有一点费解。盲目照着做也能基本满足需要,但是初学者可能只能停留一知半解。本文在《巧用》一文的基础上,总结利用「坚果云」提供的免费同步网盘实现托管私人Git项目。
知识
Git提供了大量操作命令,这对很多人来说是一个坎。但是,如果我们了解「版本控制事务」的一些实质,对这些命令进行分类后,会比较容易迈过这个坎。我们要对一个「项目数据」的版本仓库进行跟踪控制,第一件事是创建和配置这个仓库,接着才是对其进行实际跟踪和控制。我们称第一种为元操作(meta op),后一种为体操作(body op)。如下图:
在体操作(body op)事务里,我们将一些查看仓库状态的操作划出一小类,称为前体操作(pre body op)。
由于Git是一种分布式控制工具,它为传统的集中式版本控制引入一些新的概念和事务,这是需要特别注意的。以下罗列一些重要的概念:
第一,分布式的版本仓库不是一个库,而是多个(实例),所以当我们创建新库时,是在创建一个仓库系统(由多个仓库实例组成),所以有clone创建事务;
第二,由于有多个相同仓库实例,并且有本地与远程的概念,所以版本仓库天生有remote属性,所以有remote配置事务;
第三,由于团队每人都拥有一个完整的仓库,故Git没有明显的签出(Checkout)和工作副本(working copy)的概念;
第四,由于有多个相同仓库实例,故Git有一个同步实例的配置事务,所以有fetch, push 和 pull 等事务;
第五,在「源码项目」内的.git 目录就是(本地)版本仓库实例所在,「源码项目」目录数据(.git 目录以外)就是working copy;远程库没有(也不需要)working copy,这就是「创建远程库」的--bare参数的意义;
思路
使用同步网盘实现托管私人Git项目(多人异地项目版本控制)的基本思路是:
1` 在本地机器分别创建本地仓库和“远程”仓库;
2`再将本地仓库的远程库属性(用git remote)指向为本地这个「假远程仓库」;
3` 将假“远程”仓库的数据目录用同步盘实现网络同步;
4` 团队其他人在自己的机器上配置同步盘;
5` 再从这个盘上的假远程仓库复制下来;
假设我们的项目叫myproject,那我们在文件系统里分别新建两个文件目录,分别保存本地仓库(/myproject_local)和远程仓库(/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”
2.1 配置本地仓库的远程库属性
$cd ~/myproject_local$ git remote add origin ~/net.syc.dir/myproject_remotemaster
2.2同步两个仓库实例,完整构建一个 Git版本控制系统
$ git push origin master
3. 配置同步盘
安装好同步网盘客户端后,将“远程”仓库的目录~/net.syc.dir/myproject_remote添加同步任务即可,细节略
4.细节略
5.细节略