Git基础知识精讲

作者:日期:2017-11-23 16:59:24 点击:333

Linux Torvalds在 1991 年创立了开源的Linux,从此Linux系统不断发展,已经成为最大的服务器系统软件;Linux虽然创立了Linux,但Linux的壮大是靠全世界热情的志愿者参与的,这么多人在世界各地为Linux编写代码,那Linux的代码是如何管理的呢?

事实是,在2002年以前,世界各地的志愿者把源代码文件通过diff的方法发给Linux,然后由Linux本人通过手工方法合并代码!
你也许会想,为什么Linux不把Linux代码放到版本把持系统里呢?不是有 CVS SVN 这些免费的版本把持系统吗?因为Linux坚定地反对CVS和SVN,这些 集中式 的版本把持系统不但速度 ,而且必须 联网 才干应用••。有一些商用的版本把持系统,虽然比CVS¶••⊿SVN好用,但那是付费的,和Linux的开源精力不符••。

不过,到了2002年,Linux 系统已经发展了十年了,代码库之大让 Linux很难持续通过手工方法管理了,社区的弟兄们也对这种方法表达了强烈不满,于是Linux选择了一个商业的版本把持系统 BitKeeper ,BitKeeper的东家BitMover公司出于人道主义精力,授权Linux社区免费应用这个版本把持系统••。

安定团结的大好局面在 2005 年就被打破了,原因是Linux社区牛人凑集,不免沾染了一些梁山好汉的江湖习惯••。开发Samba的Andrew试图破解BitKeeper的协议,被BitMover公司创造了(监控工作做得不错!),于是BitMover公司怒了,要收回Linux社区的免费应用权••。

Linux花了 两周时间 自己用 C 写了一个散布式版本把持系统,这就是Git!一个月之内,Linux系统的源码已经由Git管理了!

Git迅速成为最风行的散布式版本把持系统,尤其是 2008GitHub 网站上线了,它为开源项目 免费 供给Git存储 ,无数开源项目开端迁移至GitHub,包含jQuery,PHP,Ruby等等••。

1¶••⊿什么是版本把持系统

如果你用Microsoft Word写过长篇大论,那你必定有这样的经历:
想删除一个段落,又怕将来想恢复找不回来怎么办?有措施,先把当前文件“另存为…”一个新的Word文件,再接着改••。改到必定程度,再“另存为…”一个新文件,这样一直改下去,最后你的Word文档变成了这样:

Alt text

过了一周,你想找回被删除的文字,但是已经记不清删除前保存在哪个文件里了,只好一个一个文件去找••。

看着一堆乱七八糟的文件,想保存最新的一个,然后把其他的删掉,又怕哪天会用上,还不敢删,真愁闷

更要命的是,有些部分需要你的同事赞助填写,于是你把文件Copy到U盘里给她,然后你持续修正Word文件••。一天后,同事再把Word文件传给你,此时你必须想想,发给她之后到你收到她的文件期间,你作了哪些修正,得把你的修正和她的部分合并••。

于是你想,如果有一个软件,不但能主动帮我记载每次文件的修正,还可以让同事 协作编辑 ,这样就不用自己管理一堆类似的文件了,也不需要把文件传来传去••。如果想查看某次修正,只需要在软件里瞄一眼就可以,岂不是很方便?

这个软件用起来就应当像这个样子,能记载每次文件的修正:

Alt text

Git是目前全世界最主流的 版本把持系统 之一

  • 备份文件

类似于用网盘备份电影••。我们的代码也需要备份••。修正完了以后提交给版本库进行保管,哪一天代码没了也可以找回来••。比如我们打游戏就要存档,万一挂了还可以从上个存档的处所重玩••。

  • 记载历史

和网盘不同,网盘保存的是最新的状态,历史的记载都没有了,修正的记载也都找不回来了,我想知道文件里的哪一行是我哪一天加进去的••。网盘是不知道的••。
但版本管理工具会记载是哪个人,在什么时候,修正了什么东西••。

  • 回到过去

如果我有一天不警惕删除了某个文件,我们可以通过历史备份找回来

  • 多端共享

手机 PAD 都可以共享代码

  • 团队协作

多人协作,处理冲突

  • 开源协作

看别人的开源代码 或者 开源自己的项目

2¶••⊿集中式 vs 散布式

Linux一直仇恨的CVS及SVN都是集中式的版本把持系统,而Git是散布式版本把持系统,集中式和散布式版本把持系统有什么差别呢?

集中式版本把持系统

版本库是集中存放在 中央服务器 的,而干活的时候,用的都是自己的电脑,所以要先从中央服务器取得最新的版本,然后开端干活,干完活了,再把自己的活推送给中央服务器••。

中央服务器就好比是一个图书馆,你要改一本书,必须先从图书馆借出来,然后回到家自己改,改完了,再放回图书馆••。

Alt text

集中式版本把持系统最大的弊病就是必须 联网 才干工作,如果在局域网内还好,带宽够大,速度够快,可如果在互联网上,遇到网速慢的话,可能提交一个10M的文件就需要5分钟,这还不得把人给憋逝世啊••。

散布式版本把持系统

与集中式版本把持系统有何不同呢?首先,散布式版本把持系统根本没有 中央服务器 ,每个人的电脑上都是一个 完整的版本库 ,这样你工作的时候,就不需要联网了,因为版本库就在你自己的电脑上••。

既然每个人电脑上都有一个完整的版本库,那多个人如何协作呢?比喻说你在自己电脑上改了文件A,你的同事也在他的电脑上改了文件A,这时你们俩之间只需把各自的修正推送给对方,就可以互相看到对方的修正了••。

和集中式版本把持系统相比,散布式版本把持系统的安全性要高很多,因为每个人电脑里都有完整的版本库 ,某一个人的电脑坏掉了不要紧,随便从其他人那里复制一个就可以了••。而集中式版本把持系统的中央服务器要是出了问题,所有人都没法干活了••。

在实际应用散布式版本把持系统的时候,其实很少在两人之间的电脑上推送版本库的修正,因为可能你们俩不在一个局域网内,两台电脑互相访问不了,也可能今天你的同事病了,他的电脑压根没有开机••。因此散布式版本把持系统通常也有一台充当“中央服务器”的电脑,但这个服务器的作用仅仅是用来方便“交换”大家的修正,没有它大家也一样干活,只是交换修正不方便而已••。

Alt text

当然,Git的优势不单是不必联网这么简略,后面我们还会看到Git极其壮大的 分支 管理,把SVN等远远抛在了后面••。

课后扩大:集中式和散布式版本管理系统的差别?
1¶••⊿集中式版本把持系统:所有的版本备份和历史记载都在中央服务器上,每个人的电脑仅仅是一个开发代码的处所而已;如果想要查看历史记载,我们必须联网,访问到中央服务器才可以••。

2¶••⊿散布式版本把持系统:每个人都是一个单独的版本把持系统,在自己的本地就可以创立一个仓库,可以记载版本和历史;我们也可以向集中式一样,建立一个中央服务器,每个人可以把自己本地的信息推送到中央服务器上(仅仅是为了方便团队之间互相观看)

3¶••⊿Git的安装

windows系统

windows下要应用很多Linux/Unix的工具时,需要cygwin 这样的模仿环境,git也一样,cygwin的安装和配置都比较复杂,就不建议你折腾了••。不过有高人已经把模仿环境和git都打包好了,名叫msysgit ,只需要下载一个单独的exe安装程序,其他什么也不用装,绝对好用••。

msysgit 是windows版的Git,从下载,然后按默认选项安装即可••。

Alt text

详细安装步骤:

Alt text

Alt text

Alt text

Alt text

Alt text

Alt text

Alt text

Alt text

Alt text

Alt text

Alt text

检查是否安装成功

Alt text

MAC下安装

两种措施:

1¶••⊿安装 homebrew ,然后通过homebrew安装Git••。先打开网站 ••。 拷贝对应脚本到终端下安装homebrew,然后在终端履行brew install git的命令••。