在上一节内容中,我们已经掌握了如何在Git仓库里对一个文件进行时光穿梭,你再也不用担心文件备份或者丢失的问题了。
Git是分布式版本控制系统,同一个Git仓库,可以分布到不同的机器上。怎么分布呢?最早,肯定只有一台机器有一个原始版本库,此后,别的机器可以“克隆”这个原始版本库,而且每台机器的版本库其实都是一样的,并没有主次之分。
你肯定会想,至少需要两台机器才能玩远程库不是?但是我只有一台电脑,怎么玩?
其实一台电脑上也是可以克隆多个版本库的,只要不在同一个目录下。不过,现实生活中是不会有人这么傻的在一台电脑上搞几个远程库玩,因为一台电脑上搞几个远程库完全没有意义,而且硬盘挂了会导致所有库都挂掉,所以我也不告诉你在一台电脑上怎么克隆多个仓库。
实际情况往往是这样,找一台电脑充当服务器的角色,每天24小时开机,其他每个人都从这个“服务器”仓库克隆一份到自己的电脑上,并且各自把各自的提交推送到服务器仓库里,也从服务器仓库中拉取别人的提交。
完全可以自己搭建一台运行Git的服务器,不过现阶段,为了学Git先搭个服务器绝对是小题大作。好在这个世界上有个叫GitHub的神奇的网站,从名字就可以看出,这个网站就是提供Git仓库托管服务的,所以,只要注册一个GitHub账号,就可以免费获得Git远程仓库。
在继续阅读后续内容前,请自行注册GitHub账号。由于你的本地Git仓库和GitHub仓库之间的传输是通过SSH加密的,所以,需要一点设置:
第一步,生成SSH Key秘钥
在用户主目录下,看看有没有.ssh目录,如果有,再看看这个目录下有没有id_rsa和id_rsa.pub这两个文件,如果已经有了,可直接跳到下一步。如果没有,打开Shell(Windows下打开Git Bash),创建SSH Key:
ssh-keygen -t rsa -C "youremail@example.com"
你需要把邮件地址换成你自己的邮件地址,然后一路回车,使用默认值即可,由于这个Key也不是用于军事目的,所以也无需设置密码。
此处注意有坑,稍有不慎就会出错,首先我们要退回主目录所以要输入cd ~ 回到主目录,然后由于生成新的SSH密钥是隐藏文件,我们要输入 open .ssh 才能打开。
此时如果一切顺利的话,会弹出一个窗口,可以在用户主目录里找到.ssh目录,里面有id_rsa和id_rsa.pub两个文件,这两个就是SSH Key的秘钥对,id_rsa是私钥,不能泄露出去,id_rsa.pub是公钥,可以放心地告诉任何人。
第二步,添加秘钥
首先,我们先注册一个github账号,此处我们默认已经注册好了,如果没有请点击链接注册(https://github.com/)。
注册完成后我们点击设置
第三步,连接本地仓库
首先我们新建一个库:
目前,在GitHub上的这个xiaoxiong仓库还是空的,GitHub告诉我们,可以从这个仓库克隆出新的仓库,也可以把一个已有的本地仓库与之关联,然后,把本地仓库的内容推送到GitHub仓库。
接下来我们回到终端,首先我们在本地文件目录下输入
git remote add origin git@github.com:a12345rwaj/learngit.git
git push -u origin master
邮箱名字换成自己的就可以了
看看远程仓库里是不是已经有了我们的文件了呢~
从现在起,只要本地作了提交,就可以通过命令:
git push origin master
将文件推送到远程仓库。
错误信息处理
另外连接远程仓库如果报错的话,可能是因为本地仓库中缺少README.md文件
可以通过如下命令进行代码合并【注:pull=fetch+merge】
git pull --rebase origin master
执行上面代码后可以看到本地代码库中多了README.md文件
此时再执行语句 git push -u origin master即可完成代码上传到github。
第四步,从远程仓库克隆
上面我们讲了先有本地库,后有远程库的时候,如何关联远程库。
现在,假设我们从零开始,那么最好的方式是先创建远程库,然后,从远程库克隆。
首先我们在github中创建一个新的仓库名字叫test。
我们可以先看看本地文件目录:
可以看到本地目录没有test文件夹,接下来我们克隆一个本地库:
首先我们回到终端,返回根目录然后输入:
git clone git@github.com:michaelliao/test.git
注意把Git库的地址换成你自己的,然后我们可以看到根目录下已经多了一个test文件夹,进入test目录看看,已经有README.md文件了。
如果有多个人协作开发,那么每个人各自从远程克隆一份就可以了。
你也许还注意到,GitHub给出的地址不止一个,还可以用https://github.com/michaelliao/test.git
这样的地址。实际上,Git支持多种协议,默认的git://使用ssh,但也可以使用https等其他协议。
使用https除了速度慢以外,还有个最大的麻烦是每次推送都必须输入口令,但是在某些只开放http端口的公司内部就无法使用ssh协议而只能用https。
最后我们练习一下将代码推送到远程仓库:
首先我们将文件放入test目录下在终端推送到本地库:
然后将文件推送到远程库中:
从上面的图我们就可以看到我们的代码已经推送到github上的远程仓库中。
以上就是我对git的用法的一些简单的介绍,由于本人水平有限,想了解更多可以自己去查找资料。
(未完待续••••••!)