1.什么是git?

简介

  Git是一个开源的分布式版本控制系统,用以有效、高速的处理从很小到非常大的项目版本管理。 [1]
  Git 是 Linux Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件。
  Torvalds 开始着手开发 Git 是为了作为一种过渡方案来替代 BitKeeper,后者之前一直是 Linux 内核开发人员在全球使用的主要源代码工具。开放源码社区中的有些人觉得 BitKeeper 的许可证并不适合开放源码社区的工作,因此 Torvalds 决定着手研究许可证更为灵活的版本控制系统。尽管最初 Git 的开发是为了辅助 Linux 内核开发的过程,但是我们已经发现在很多其他自由软件项目中也使用了 Git。例如 最近就迁移到 Git 上来了,很多 Freedesktop 的项目也迁移到了 Git 上。 [1]

特点

  分布式和集中式的最大区别在于开发者可以本地提交。每个开发者机器上都有一个服务器的数据库。
  下图是经典的git开发过程。
  Git的功能特性:
  从一般开发者的角度来看git有以下功能:
  1:从服务器上克隆数据库(包括代码和版本信息)到单机上。
  2:在自己的机器上创建分支,修改代码。
  3:在单机上自己创建的分支上提交代码。
  4:在单机上合并分支。
  5:新建一个分支,把服务器上最新版的代码fetch下来,然后跟自己的主分支合并。
  6:生成 补丁 (patch),把补丁发送给主开发者。
  7:看主开发者的反馈,如果主开发者发现两个一般开发者之间有冲突(他们之间可以合作解决的冲突),就会要求他们先解决冲突,然后再由其中一个人提交。如果主开发者可以自己解决,或者没有冲突,就通过。
  8:一般开发者之间解决冲突的方法,开发者之间可以使用pull 命令解决冲突,解决完冲突之后再向主开发者提交补丁。

功能

  从主开发者的角度(假设主开发者不用开发代码)看,git有以下功能:
  1:查看邮件或者通过其它方式查看一般开发者的提交状态。
  2:打上 补丁 ,解决冲突(可以自己解决,也可以要求开发者之间解决以后再重新提交,如果是开源项目,还要决定哪些补丁有用,哪些不用)。
  3:向公共服务器提交结果,然后通知所有开发人员。
  优点:
  适合 分布式开发 ,强调个体。
  公共服务器压力和数据量都不会太大。
  速度快、灵活。
  任意两个开发者之间可以很容易的解决冲突。
  离线工作。
  缺点:
  资料少(起码中文资料很少)。
  学习周期相对而言比较长。
  不符合常规思维。
  代码保密性差,一旦开发者把整个库克隆下来就可以完全公开所有代码和版本信息。

2.什么是github?

GitHub可以托管各种git库,并提供一个web界面,但与其它像 SourceForge或Google Code这样的服务不同,GitHub的独特卖点在于从另外一个项目进行分支的简易性。为一个项目贡献代码非常简单:首先点击项目站点的“fork”的按钮,然后将代码检出并将修改加入到刚才分出的代码库中,最后通过内建的“pull request”机制向项目负责人申请代码合并。已经有人将GitHub称为代码玩家的MySpace。

  在GitHub进行分支就像在Myspace(或Facebook…)进行交友一样,在社会关系图的节点中不断的连线。
  GitHub项目本身自然而然的也在GitHub上就像托管,只不过在一个私有的,公共视图不可见的库中。 开源项目 可以免费托管,但私有库则并不如此。Chris Wanstrath,GitHub的开发者之一,肯定了通过付费的私有库来在财务上支持免费库的托管这一计划。


3.github使用(GitHub for Windows

以下我们能下下载springsource在github上托管的项目为例 :  https://github.com/SpringSource/spring-framework

要使用github需要先注册一个github账号,

3.1 注册免费账号

https://github.com/signup/free

3.2 下载安装github

网址: http://windows.github.com/


下载完成后安装即可(此处下载的文件并非完整的安装文件,只是一个安装引导文件它还会去amazon下载完整的安装文件30多M,根据网络情况会花点时间)

3.3 用github for windows下载spring源码

登陆github账号 web和客户端同时登陆

进入spring托管项目页面 https://github.com/SpringSource/spring-framework




点击上图中红色标记外按钮 "Clone In Windows"

此时会自动打开github for windows并下载源码到本地仓库,如图



3.4 其它

如果在github网站上没有登陆账号就点击按钮 "Clone In Windows",  这时会跳转到 github for windows下载页面 , 如登陆了而github for windows没有登陆下载时会先登陆


4.创建仓库,提交到本地及github远程服务上

创建一个仓库。点击上面的 “ +Add” 按钮创建一个新的仓库,输入相关信息:
 
 新建的仓库还没有真正地提交到本地仓库,相当于这只是一个new的修改,github简化了一些操作过程,对于任何修改,只需要添加评论就可以提交到本地仓库,然后这个时候才可以提交到远程仓库,所以我们来添加一条评论:
 
 
在每次添加一个评论之后,就相当于向本地仓库提交了一本版本,之后,就可以选择一个版本向远处仓库提交了。
 
 这个时候我们就可以Publish一个仓库了,Publish之后按钮就变成in sync文字,表示以后的修改提交就是同步,这个时候你到你的github上看应该就会多一个仓库了:
 
 
添加项目,仓库在本地保存在一个文件夹中,Github for windows会监视这个文件夹,任何修改都会在仓库中看到,然后像上面一样添加评论就可以将修改提交到本地仓库,这里我们打开仓库目录,往里面添加一个项目:
 
 
 
 将修改提交到本地仓库,回到Github for windows中,已经可以看到刚才添加的项目了,同样,提交注释提交到本地仓库:
 
 
 
最后,点击sync将本地仓库提交到github
参与开源项目协同开发:
    github现在已经深度支持Windows开发者了,现在每个在github的开源项目前面都有一个“Clone in Windows”的按钮,我们可以Clone任何我们感兴趣的开源项目,然后在地进行修改,参与开源项目的开发。
    点击该按钮之后,浏览器会要求打开Github for Windows,并下载项目至本地,新建一个本地仓库:
 
总结:github for Windows简化了一些概念和操作,并且几乎所有主要操作都通过图形界面来完成,基本上能完成日常写作了。这些主要的简化包括:
          1. 将push到远程仓库简化为一个同步按钮
          2. 将提交到本地仓库简化为只需要对一些列修改添加评论

Logo

更多推荐