读书人

github施用一-入门

发布时间: 2012-10-20 14:12:48 作者: rapoo

github使用一-入门
1.什么是git?

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

  下图是经典的git开发过程。 github施用一-入门

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

  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/free3.2 下载安装github

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

github施用一-入门

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

3.3 用github for windows下载spring源码

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

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

github施用一-入门



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

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

github施用一-入门


3.4 其它

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


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

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

读书人网 >软件开发

热点推荐