远程仓库: git的杀招

到目前为止,我们已经掌握了如何在Git仓库里对一个文件进行时光穿梭,你再也不用担心文件备份或者丢失的问题了。

Git是分布式版本控制系统,同一个Git仓库,可以分布到不同的机器上。怎么分布呢?最早,肯定只有一台机器有一个原始版本库,此后,别的机器可以“克隆”这个原始版本库,而且每台机器的版本库其实都是一样的,并没有主次之分。

实际情况往往是这样,找一台电脑充当服务器的角色,每天24小时开机,其他每个人都从这个“服务器”仓库克隆一份到自己的电脑上,并且各自把各自的提交推送到服务器仓库里,也从服务器仓库中拉取别人的提交。

完全可以自己搭建一台运行Git的服务器,不过现阶段,为了学Git先搭个服务器绝对是小题大作。好在这个世界上有个叫GitHub的神奇的网站,从名字就可以看出,这个网站就是提供Git仓库托管服务的,所以,只要注册一个GitHub账号,就可以免费获得Git远程仓库。

在继续阅读后续内容前,请自行注册GitHub账号。由于你的本地Git仓库和GitHub仓库之间的传输是通过SSH加密的,所以,需要一点设置:

第1步:创建SSH Key。在用户主目录下,看看有没有.ssh目录,如果有,再看看这个目录下有没有id_rsaid_rsa.pub这两个文件,如果已经有了,可直接跳到下一步。如果没有,打开Shell(Windows下打开Git Bash),创建SSH Key:

  1. $ ssh-keygen -t rsa -C "youremail@example.com"

你需要把邮件地址换成你自己的邮件地址,然后一路回车,使用默认值即可,由于这个Key也不是用于军事目的,所以也无需设置密码。

如果一切顺利的话,可以在用户主目录里找到.ssh目录,里面有id_rsaid_rsa.pub两个文件,这两个就是SSH Key的秘钥对,id_rsa是私钥,不能泄露出去,id_rsa.pub是公钥,可以放心地告诉任何人。

第2步:登陆GitHub,打开“Account settings”,“SSH Keys”页面:

然后,点“Add SSH Key”,填上任意Title,在Key文本框里粘贴id_rsa.pub文件的内容:

添加SSH秘钥

为什么GitHub需要SSH Key呢?因为GitHub需要识别出你推送的提交确实是你推送的,而不是别人冒充的,而Git支持SSH协议,所以,GitHub只要知道了你的公钥,就可以确认只有你自己才能推送。

当然,GitHub允许你添加多个Key。假定你有若干电脑,你一会儿在公司提交,一会儿在家里提交,只要把每台电脑的Key都添加到GitHub,就可以在每台电脑上往GitHub推送了。

最后友情提示,在GitHub上免费托管的Git仓库,任何人都可以看到喔(但只有你自己才能改)。所以,不要把敏感信息放进去(这个确实需要注意,可以共享的东西随便存储大家看看也没什么,关键的信息和资料还是要注意些)。

如果你不想让别人看到Git库,有两个办法,一个是交点保护费,让GitHub把公开的仓库变成私有的,这样别人就看不见了(不可读更不可写)。另一个办法是自己动手,搭一个Git服务器,因为是你自己的Git服务器,所以别人也是看不见的。这个方法我们后面会讲到的,相当简单,公司内部开发必备。

确保你拥有一个GitHub账号后,我们就即将开始远程仓库的学习。

添加远程库

你已经在本地创建了一个Git仓库后,又想在GitHub创建一个Git仓库,并且让这两个仓库进行远程同步,这样,GitHub上的仓库既可以作为备份,又可以让其他人通过该仓库来协作,真是一举多得。

(下面我自己参考博文构建一个新的远程库)

首先,登陆GitHub,然后,在右上角找到“Create a new repo”按钮,创建一个新的仓库:
添加仓库

因为我最近想要学习bioconductor,所以添加一个记录库,方便记录、查找、更新。

在Repository name填入bioconductor_learn,其他保持默认设置,点击“Create repository”按钮,就成功地创建了一个新的Git仓库。

目前,在GitHub上的这个仓库还是空的,GitHub告诉我们,可以从这个仓库克隆出新的仓库,也可以把一个已有的本地仓库与之关联,然后,把本地仓库的内容推送到GitHub仓库。

  1. # create a new repository on the command line
  2. echo "# bioconductor_learn" >> README.md
  3. git init
  4. git add README.md
  5. git commit -m "first commit"
  6. git remote add origin https://github.com/ShixiangWang/bioconductor_learn.git
  7. git push -u origin master
  1. # push an existing repository from the command line
  2. git remote add origin https://github.com/ShixiangWang/bioconductor_learn.git
  3. git push -u origin master

现在,我们根据GitHub的提示,运行相应命令

  1. wsx@wsx-ubuntu:~/桌面/Bioconductor_learn$ git add README.md
  2. wsx@wsx-ubuntu:~/桌面/Bioconductor_learn$ git commit -m "first commit"
  3. [master (根提交) c3cb52a] first commit
  4. 1 file changed, 1 insertion(+)
  5. create mode 100644 README.md
  6. wsx@wsx-ubuntu:~/桌面/Bioconductor_learn$ git remote add origin https://github.com/ShixiangWang/bioconductor_learn.git
  7. wsx@wsx-ubuntu:~/桌面/Bioconductor_learn$ git push -u origin masterUsername for 'https://github.com': ShixiangWang
  8. Password for 'https://ShixiangWang@github.com':
  9. 对象计数中: 3, 完成.
  10. 写入对象中: 100% (3/3), 243 bytes | 0 bytes/s, 完成.
  11. Total 3 (delta 0), reused 0 (delta 0)
  12. To https://github.com/ShixiangWang/bioconductor_learn.git
  13. * [new branch] master -> master
  14. 分支 master 设置为跟踪来自 origin 的远程分支 master

请千万注意,把上面的账户名替换成你自己的GitHub账户名,否则,你在本地关联的就是我的远程库,关联没有问题,但是你以后推送是推不上去的,因为你的SSH Key公钥不在我的账户列表中。

添加后,远程库的名字就是origin,这是Git默认的叫法,也可以改成别的,但是origin这个名字一看就知道是远程库。

把本地库的内容推送到远程,用git push命令,实际上是把当前分支master推送到远程。

由于远程库是空的,我们第一次推送master分支时,加上了-u参数,Git不但会把本地的master分支内容推送的远程新的master分支,还会把本地的master分支和远程的master分支关联起来,在以后的推送或者拉取时就可以简化命令。

推送成功后,可以立刻在GitHub页面中看到远程库的内容已经和本地一模一样。

从现在起,只要本地作了提交,就可以通过命令:

  1. $ git push origin master

把本地master分支的最新修改推送至GitHub,现在,你就拥有了真正的分布式版本库!

小结:

要关联一个远程库,使用命令git remote add origin git@server-name:path/repo-name.git

关联后,使用命令git push -u origin master第一次推送master分支的所有内容;

此后,每次本地提交后,只要有必要,就可以使用命令git push origin master推送最新修改;

分布式版本系统的最大好处之一是在本地工作完全不需要考虑远程库的存在,也就是有没有联网都可以正常工作,而SVN在没有联网的时候是拒绝干活的!当有网络的时候,再把本地提交推送一下就完成了同步,真是太方便了!

远程库克隆

如果是克隆别人的库,直接调用git clone命令后接库名地址即可。

自己建库然后克隆略显麻烦,多了前面创库的几个步骤,然后后面也是用git clone命令。

具体参考:从远程库克隆