Press "Enter" to skip to content

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

需求

我有一个早前一人开发的源代码项目,现在想对其进行版本跟踪,用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. 1` 在本地机器分别创建本地仓库和“远程”仓库;
  2. 2`再将本地仓库的远程库属性(用git remote)指向为本地这个「假远程仓库」;
  3. 3` 将假“远程”仓库的数据目录用同步盘实现网络同步;
  4. 4` 团队其他人在自己的机器上配置同步盘;
  5. 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.细节略

Be First to Comment

Leave a Reply

Your email address will not be published. Required fields are marked *