git 基础知识精讲

作者:日期:2018-05-26 19:29:12 点击:261

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,从http://git-scm.com/下载,然后按默认选项安装即可。

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。先打开网站 http://brew.sh/。 拷贝对应脚本到终端下安装homebrew,然后在终端执行brew install git的命令。