获取Git仓库
通常有两中获取Git项目仓库的方式:
- 将尚未进行版本控制的本地目录转换为Git仓库。
- 从其他服务器克隆一个已存在的Git仓库。
两种方式都会在你的本地机器上得到一个工作就绪的Git仓库。
在已存在目录中初始化仓库
如果你有一个尚未进行版本控制的项目目录,想要用Git来控制它,那么首先需要进入该项目目录中,然后执行:
$ git init
该命令将创建一个名为.git
的子目录,这个子目录含有你初始化的Git仓库中所有的必须文件,这些文件是Git仓库的骨干。但是,在这个时候,我们仅仅是做了一个初始化的操作,你的项目里的文件还没有被跟踪。
如果在一个已经存在文件的文件夹(非空文件夹)中进行版本控制,你应该开始追踪这些文件并进行初始提交。可以通过git add
命令来指定所需的文件来进行跟踪,然后执行git commit
:
$ git add *.c(文件名)
$ git add LICENSE
$ git commit -t 'initial project version'
稍后我们再逐一解释这些指令的行为。现在,你已经得到了一个存在被追踪文件与初始提交的Git仓库。
克隆已有的仓库
如果你想获得一份已经存在了的Git仓库的拷贝,比如说,你想为某个开源项目贡献自己的一份力,这时就要用到git clone
命令,如果你对其他的VCS系统很熟悉,请留心一下你所使用的命令时“clone”而不是“checkout”。这是Git区别与其他版本控制系统的一个重要特性,Git克隆的是该Git仓库服务器上的几乎所有数据,而不是仅仅复制完成你的工作所需文件。当你执行git clone
命令的时候,默认配置下远程Git仓库中的每一个文件的每一个版本都将被拉取下来。事实上,如果你的服务器的磁盘坏掉了,你通常可以使用任何一个克隆下来的用户端来重建服务器上的仓库(虽然可能丢失某些服务器端的钩子(hook)设置,但是所有版本的数据仍在)。
克隆仓库的命令是git clone <url>
。比如,要克隆Git的链接库libgit2
,可以用下面的命令:
$ git clone https://github.com/libgit2/libgit2
这会在当前目录下创建一个名为“libgit2”的目录,并在这个目录下初始化一个.git
文件夹,从远程仓库拉取下所有数据放入.git
文件夹,然后从中读取最新版本的文件的拷贝。如果你进入到这个新建的libgit2
文件夹,你会发现所有的项目文件已经在里面了,准备就绪等待后续的开发和使用。
如果你想在克隆远程仓库的时候,自定义本地仓库的名字,你可以通过额外的参数指定新的目录名:
$ git clone https://github.com/libgit2/libgit2 mylibgit
这回执行与上一条命令相同的操作,但目标目录名变成了mulibgit
。
Git支持多种数据传输协议。上面的例子使用的是https://
协议,不过你也可以使用git://
协议或者使用SSH传输协议,比如user@server:path/to/repo.git
。在服务器上搭建Git将会介绍这些协议在服务器端如何配置使用,以及各种方式之间的利弊。