git的使用(二)

在上一节内容中,我们已经掌握了如何在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 "[email protected]"
git的使用(二)_第1张图片
终端代码执行效果

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

此处注意有坑,稍有不慎就会出错,首先我们要退回主目录所以要输入cd ~ 回到主目录,然后由于生成新的SSH密钥是隐藏文件,我们要输入 open .ssh 才能打开。

git的使用(二)_第2张图片
终端代码执行效果

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

git的使用(二)_第3张图片
终端代码执行效果

第二步,添加秘钥

首先,我们先注册一个github账号,此处我们默认已经注册好了,如果没有请点击链接注册(https://github.com/)。

注册完成后我们点击设置

git的使用(二)_第4张图片
设置
git的使用(二)_第5张图片
新建秘钥
git的使用(二)_第6张图片
添加秘钥
git的使用(二)_第7张图片
添加完成

第三步,连接本地仓库

首先我们新建一个库:

git的使用(二)_第8张图片
点击新建菜单
git的使用(二)_第9张图片
新建仓库
git的使用(二)_第10张图片
创建完成

目前,在GitHub上的这个xiaoxiong仓库还是空的,GitHub告诉我们,可以从这个仓库克隆出新的仓库,也可以把一个已有的本地仓库与之关联,然后,把本地仓库的内容推送到GitHub仓库。
接下来我们回到终端,首先我们在本地文件目录下输入

git remote add origin [email protected]:a12345rwaj/learngit.git
git push -u origin master
终端代码执行效果

邮箱名字换成自己的就可以了
看看远程仓库里是不是已经有了我们的文件了呢~

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

git push origin master

将文件推送到远程仓库。


错误信息处理

另外连接远程仓库如果报错的话,可能是因为本地仓库中缺少README.md文件

git的使用(二)_第11张图片

可以通过如下命令进行代码合并【注:pull=fetch+merge】

git pull --rebase origin master

执行上面代码后可以看到本地代码库中多了README.md文件

git的使用(二)_第12张图片

此时再执行语句 git push -u origin master即可完成代码上传到github。

第四步,从远程仓库克隆

上面我们讲了先有本地库,后有远程库的时候,如何关联远程库。
现在,假设我们从零开始,那么最好的方式是先创建远程库,然后,从远程库克隆。
首先我们在github中创建一个新的仓库名字叫test。

git的使用(二)_第13张图片

我们可以先看看本地文件目录:

git的使用(二)_第14张图片

可以看到本地目录没有test文件夹,接下来我们克隆一个本地库:
首先我们回到终端,返回根目录然后输入:

git clone [email protected]:michaelliao/test.git
git的使用(二)_第15张图片
终端代码执行效果

注意把Git库的地址换成你自己的,然后我们可以看到根目录下已经多了一个test文件夹,进入test目录看看,已经有README.md文件了。

git的使用(二)_第16张图片

如果有多个人协作开发,那么每个人各自从远程克隆一份就可以了。

你也许还注意到,GitHub给出的地址不止一个,还可以用https://github.com/michaelliao/test.git
这样的地址。实际上,Git支持多种协议,默认的git://使用ssh,但也可以使用https等其他协议。

使用https除了速度慢以外,还有个最大的麻烦是每次推送都必须输入口令,但是在某些只开放http端口的公司内部就无法使用ssh协议而只能用https。


最后我们练习一下将代码推送到远程仓库:

首先我们将文件放入test目录下在终端推送到本地库:

git的使用(二)_第17张图片
终端代码执行效果
git的使用(二)_第18张图片
远程库

然后将文件推送到远程库中:

git的使用(二)_第19张图片
终端代码执行效果
git的使用(二)_第20张图片
远程库

从上面的图我们就可以看到我们的代码已经推送到github上的远程仓库中。

以上就是我对git的用法的一些简单的介绍,由于本人水平有限,想了解更多可以自己去查找资料。

(未完待续••••••!)

你可能感兴趣的:(git的使用(二))