Git版本控制工具(三)----远程仓库GitHub的使用

2019-12-18 作者:www.243.net   |   浏览(186)

【声明】

欢迎转载,但请保留文章原始出处→_→

生命壹号:

文章来源:

 

【系列】Git版本控制工具(持续更新)

Git版本控制工具(一)----git的安装及创建版本库

Git版本控制工具(二)----本地版本库的常用操作

Git版本控制工具(三)----远程仓库GitHub的使用

 

Git版本控制工具(三)----远程仓库GitHub的使用。【正文】

即使是周末,也不能停止学习的脚步,在之前的两篇文章中,我们已经掌握了如何在Git仓库里对一个文件进行时光穿梭,你再也不用担心文件备份或者丢失的问题了。今天就来一起学习一下大名鼎鼎的GitHub网站是怎么用的。如果网站进不去,该怎么做你懂得。如果不嫌弃的话,可以用我的邀请链接:   这样的话,双方都能加十天的有效期,嘿嘿~~~

一、GitHub的引入:                                                                                                                ** **

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

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

Git版本控制工具(三)----远程仓库GitHub的使用。1、GitHub的介绍

其实完全可以自己搭建一台运行Git的服务器,不过现阶段,为了学Git先搭个服务器绝对是小题大作。好在这个世界上有个叫GitHub的神奇的网站,它是全球最大的代码托管网站,主要借助Git来进行版本控制的。任何开源软件都可以免费地将代码提交到Github上,网址如下:

首先需要注册一个GitHub账号,就可以免费获得Git远程仓库。

2、生成ssh keys

官方参考链接:

Git版本控制工具(三)----远程仓库GitHub的使用。由于你的本地Git仓库和GitHub仓库之间的传输是通过SSH加密的,所以,需要一点设置:

第一步:Git版本控制工具(三)----远程仓库GitHub的使用。生成SSH Key。在用户主目录下,看看有没有.ssh目录,如果有,再看看这个目录下有没有id_rsa和id_rsa.pub这两个文件,如果有的话,直接跳过此如下命令,如果没有的话,打开命令行,输入如下命令:

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

Git版本控制工具(三)----远程仓库GitHub的使用。你需要把邮件地址换成你自己的邮件地址,然后一路回车,使用默认值即可,由于这个Key也不是用于军事目的,所以也无需设置密码。

运行效果如下:

图片 1

如果一切顺利的话,可以在用户主目录里找到.ssh目录,里面有id_rsa和id_rsa.pub两个文件:

图片 2

这两个就是SSH Key的秘钥对,id_rsa是私钥,不能泄露出去,id_rsa.pub是公钥,可以放心地告诉任何人。

第二步:添加SSH key到GitHub网站上。登录github,打开“settings”中的SSH Keys页面,然后点击“Add SSH Key”,填上任意title,在Key文本框里黏贴id_rsa.pub文件的内容:

图片 3

上图中,点击 Add Key,你就应该可以看到已经添加的key:

图片 4

第三步:验证连接是否成功。首先在.ssh目录下添加名叫做config的文件,没有后缀名,添加内容如下:(不然稍后会报错:ssh connect to host port 22 bad file number)

Host github.com
User git
Hostname ssh.github.com
PreferredAuthentications publickey
IdentityFile ~/.ssh/id_rsa
Port 443

然后,在Git Bash输入如下命令进行验证:

ssh -T git@github.com

输入之后,可能会看到一下提示:

#The authenticity of host '[ssh.github.com]:443([192.30.252.150]:443)' can't be established.

# RSA key fingerprint is 16:27:ac:a5:76:28:2d:36:63:1b:56:4d:eb:df:a6:48.

# Are you sure you want to continue connecting (yes/no)?

不用担心确保fingerprint是对的,然后根据提示输入如下命令:

yes

如果成功,效果如下:

图片 5 

而且,ssh目录下还会多出一个文件:

图片 6

注:为什么GitHub需要SSH Key呢?因为GitHub需要识别出你推送的提交确实是你推送的,而不是别人冒充的,而Git支持SSH协议,所以,GitHub只要知道了你的公钥,就可以确认只有你自己才能推送。当然,GitHub允许你添加多个Key。假定你有若干电脑,你一会儿在公司提交,一会儿在家里提交,只要把每台电脑的Key都添加到GitHub,就可以在每台电脑上往GitHub推送了。

最后友情提示,在GitHub上免费托管的Git仓库,任何人都可以看到(但只有你自己才能改)。所以,不要把敏感信息放进去。

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

 

二、添加远程库:                                                                                                                   

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

首先,登陆GitHub,然后,在右上角找到“Create a new repo”按钮,创建一个新的仓库,起个名字,如下图所示:

图片 7

仓库创建好后,效果如下:

图片 8

目前,在GitHub上的这个learngit仓库还是空的,而且,这个仓库的地址是:

 

三、将本地库的内容push到远程库中                                                                                                

上一段中,我们已经建好了一个空白的远程库;现在,我们根据上图中GitHub的提示,把一个已有的本地仓库放到上面的远程库当中。

首先在本地创建一个版本库AndroidTest并commit提交:

git init
git add .
git commit - "第一次提交"

然后,在本地的AndroidTest仓库下运行命令来关联远程库

git remote add origin git@github.com/smyhvae/GitTest.git

因为我们之前在网站上已经创建好了,所以系统会提示:remote origin already exsists。恩,是这样的。

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

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

下一步,就可以把本地库的所有内容推送到远程库上

git push -u origin master

如果成功,上面两行命令的效果如下:

图片 9

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

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

图片 10

上面的这些文件是我在本地建的工程文件,很明显,已经成功push到了GitHub上。

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

$ git push origin master

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

【总结】

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

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

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

 

四、从远程库克隆到本地                                                                                                             

上一段中我们讲了先有本地库,后有远程库的时候,如何关联远程库。

现在,假设我们从零开发,那么最好的方式是先创建远程库,然后从远程库克隆到本地

准备工作:

首先,登陆GitHub,创建一个新的仓库,名字叫GitTest02:

图片 11

上图中,勾选箭头处的按钮,GitHub会自动为我们创建一个README.md文件。创建完毕后,可以看到README.md文件:

图片 12

开始克隆:

先在本地新建一个空的文件夹作为工作目录,我新建的目录是:D:workspace。因为接下来要将远程的文件克隆到这个目录下。

然后跳到D:workspace目录下,使用git clone命令开始克隆:

git clone git@github.com:smyhvae/GitTest02.git

上方命令中,注意改成自己账户的用户名。运行成功后,效果如下:

图片 13

这时,我们再回到本地的D:workspace目录下看一看:

图片 14

上图说明,我是将远程的整个文件夹GitTest02克隆到了workspace目录下。现在打开文件夹GitTest02看一看:

图片 15

上图中,看到了我们在远程建的readme.md文件和.git文件夹,这是我们想要的结果。现在将GitTest02文件夹下的所有文件复制到上一层目录,这样就能将整个workspace工程目录添加到版本控制中去了。注意.git是一个隐藏目录,在复制的时候千万不要 漏掉。复制完成后就可以把GitTest02文件夹删了 。最终,workspace工程的目录结构就和远程的目录结构一模一样了:(只是工程的名字不一样而已)

图片 16

这时,如果在本地的workspace工程目录中继续添加了文件,就可以先把所有文件add到版本控制中去:

git add .
git commit -m "我在本地做了修改"

然后将提交的内容同步到远程版本库,也就是GitHub上:

git push origin master

注:你也许还注意到,GitHub给出的地址不止一个,还可以用

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

关于Git的分支管理,将在下一章讲到。

 

本文由金沙澳门官网网址发布于www.243.net,转载请注明出处:Git版本控制工具(三)----远程仓库GitHub的使用

关键词: