您可以捐助,支持我们的公益事业。

1元 10元 50元





认证码:  验证码,看不清楚?请点击刷新验证码 必填



  求知 文章 文库 Lib 视频 iPerson 课程 认证 咨询 工具 讲座 Modeler   Code  
会员   
 
   
 
 
     
   
 订阅
  捐助
Git版本控制工具(三)--远程仓库GitHub的使用
 
作者:生命壹号 来源:博客园 发布于 2015-03-05
  3676  次浏览      15
 

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

一、GitHub的引入:

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

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

1、GitHub的介绍

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

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

2、生成ssh keys

官方参考链接:https://help.github.com/articles/generating-ssh-keys/

由于你的本地Git仓库和GitHub仓库之间的传输是通过SSH加密的,所以,需要一点设置:

第一步:生成SSH Key。在用户主目录下,看看有没有.ssh目录,如果有,再看看这个目录下有没有id_rsa和id_rsa.pub这两个文件,如果有的话,直接跳过此如下命令,如果没有的话,打开命令行,输入如下命令:

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

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

运行效果如下:

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

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

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

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

第三步:验证连接是否成功。首先在.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是对的,然后根据提示输入如下命令:

《ssh -T git@github.com》

如果成功,效果如下:

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

注:为什么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”按钮,创建一个新的仓库,起个名字,如下图所示:

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

目前,在GitHub上的这个learngit仓库还是空的,而且,这个仓库的地址是:https://github.com/smyhvae/GitTest.git。GitHub告诉我们,可以从这个仓库克隆出新的仓库;也可以把一个已有的本地仓库与之关联,然后,把本地仓库的内容推送到GitHub仓库。

三、将本地库的内容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

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

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

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

上面的这些文件是我在本地建的工程文件,很明显,已经成功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:

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

开始克隆:

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

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

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

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

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

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

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

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

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

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

git push origin master

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

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

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

   
3676 次浏览       15
相关文章

每日构建解决方案
如何制定有效的配置管理流程
配置管理主要活动及实现方法
构建管理入门
相关文档

配置管理流程
配置管理白皮书
CM09_C配置管理标准
使用SVN进行版本控制
相关课程

配置管理实践
配置管理方法、工具与应用
多层次集成配置管理
产品发布管理
最新课程计划
信息架构建模(基于UML+EA)3-21[北京]
软件架构设计师 3-21[北京]
图数据库与知识图谱 3-25[北京]
业务架构设计 4-11[北京]
SysML和EA系统设计与建模 4-22[北京]
DoDAF规范、模型与实例 5-23[北京]

软件配置管理的问题、目的
软件配置管理规范
CQWeb 7.1性能测试与调优指南
为什么需要使用ClearCase
ClearCase与RTC的集成
利用ClearQuest 进行测试管理
更多...   


产品发布管理
配置管理方法、实践、工具
多层次集成配置管理
使用CC与CQ进行项目实践
CVS与配置管理
Subversion管理员


配置管理实践(从组织级到项目级)
通号院 配置管理规范与应用
配置管理日构建及持续集成
丹佛斯 ClearCase与配置管理
中国移动 软件配置管理
中国银行 软件配置管理
天津华翼蓝天科技 配置管理与Pvcs