Git简介、诞生、下载安装
来源
廖雪峰老师的网站
来源是廖雪峰老师的网站,写得很好易懂,这里做下笔记。
Git是什么?
-
Git是目前世界上最先进的分布式版本控制系统(没有之一)。
-
那什么是版本控制系统?
-
如果你用Microsoft Word写过长篇大论,那你一定有这样的经历:
- 想删除一个段落,又怕将来想恢复找不回来怎么办?
- 有办法,先把当前文件“另存为……”一个新的Word文件,再接着改,改到一定程度,再“另存为……”一个新文件,这样一直改下去,最后你就拥有了N个word存档。
- 史称手动管理多个“版本”的史前时代
-
过了一周,你想找回被删除的文字,但是已经记不清删除前保存在哪个文件里了,只好一个一个文件去找,真麻烦。
- 看着一堆乱七八糟的文件,想保留最新的一个,然后把其他的删掉,又怕哪天会用上,还不敢删,真郁闷。
-
更要命的是,有些部分需要你的财务同事帮助填写,于是你把文件Copy给她。然后,你继续修改Word文件。
- 一天后,同事再把Word文件传给你,此时,你必须想想,发给她之后到你收到她的文件期间,你作了哪些改动,得把你的改动和她的部分合并,真困难。
-
于是你想,如果有一个软件,不但能自动帮我记录每次文件的改动,还可以让同事协作编辑,这样就不用自己管理一堆类似的文件了,也不需要把文件传来传去。如果想查看某次改动,只需要在软件里瞄一眼就可以,岂不是很方便?
-
-
这个软件用起来就应该像这个样子,能记录每次文件的改动:
-
这样,你就结束了,进入到版本控制的新世纪。
Git的诞生
- 很多人都知道,Linus在1991年创建了开源的Linux,从此,Linux系统不断发展,已经成为最大的服务器系统软件了。
- Linus虽然创建了Linux,但Linux的壮大是靠全世界热心的志愿者参与的,这么多人在世界各地为Linux编写代码,那Linux的代码是如何管理的呢?
- 事实是,在2002年以前,世界各地的志愿者把源代码文件通过diff的方式发给Linus,然后由Linus本人通过手工方式合并代码!
- 你也许会想,为什么Linus不把Linux代码放到版本控制系统里呢?不是有CVS、SVN这些免费的版本控制系统吗?
- 因为Linus坚定地反对CVS和SVN,这些集中式的版本控制系统不但速度慢,而且必须联网才能使用。有一些商用的版本控制系统,虽然比CVS、SVN好用,但那是付费的,和Linux的开源精神不符。
- 不过,到了2002年,Linux系统已经发展了十年了,代码库之大让Linus很难继续通过手工方式管理了,于是Linus选择了一个商业的版本控制系统BitKeeper,BitKeeper的东家出于人道主义精神,授权Linux社区免费使用这个版本控制系统。
- 安定团结的大好局面在2005年就被打破了,原因是Linux社区牛人聚集,不免沾染了一些梁山好汉的江湖习气。
- 开发Samba的Andrew试图破解BitKeeper的协议(这么干的其实也不只他一个),被BitMover公司发现了(监控工作做得不错!),于是BitMover公司怒了,要收回Linux社区的免费使用权。
- Linus可以向BitMover公司道个歉,保证以后严格管教弟兄们,嗯,这是不可能的。实际情况是这样的:
- Linus花了两周时间自己用C写了一个分布式版本控制系统,这就是Git!一个月之内,Linux系统的源码已经由Git管理了!
- Git迅速成为最流行的分布式版本控制系统,尤其是2008年,GitHub网站上线了,它为开源项目免费提供Git存储,无数开源项目开始迁移至GitHub,包括jQuery,PHP,Ruby等等。
- 历史就是这么偶然,如果不是当年BitMover公司威胁Linux社区,可能现在我们就没有免费而超级好用的Git了。
集中式vs分布式
- Linus一直痛恨的CVS及SVN都是集中式的版本控制系统,而Git是分布式版本控制系统,集中式和分布式版本控制系统有什么区别呢?
集中式版本控制系统
- 版本库是集中存放在中央服务器的,而干活的时候,用的都是自己的电脑,所以要先从中央服务器取得最新的版本,然后开始干活,干完活了,再把自己的活推送给中央服务器。
- 中央服务器就好比是一个图书馆,你要改一本书,必须先从图书馆借出来,然后回到家自己改,改完了,再放回图书馆。
缺点
- 集中式版本控制系统最大的毛病就是必须联网才能工作,如果在局域网内还好,带宽够大,速度够快。
- 可如果在互联网上,遇到网速慢的话,可能提交一个10M的文件就需要5分钟,这还不得把人给憋死啊。
分布式版本控制系统
- 分布式版本控制系统根本没有“中央服务器”,每个人的电脑上都是一个完整的版本库,这样,工作的时候就不需要联网了,因为版本库就在你自己的电脑上。
多人协作
- 比方说你在自己电脑上改了文件A,你的同事也在他的电脑上改了文件A,这时,你们俩之间只需把各自的修改推送给对方,就可以互相看到对方的修改了。
- 分布式版本控制系统通常也有一台充当“中央服务器”的电脑,但这个服务器的作用仅仅是用来方便“交换”大家的修改,没有它大家也一样干活,只是交换修改不方便而已。
- 在实际使用分布式版本控制系统的时候,其实很少在两人之间的电脑上推送版本库的修改。
- 因为可能你们俩不在一个局域网内,两台电脑互相访问不了
- 也可能今天你的同事病了,他的电脑压根没有开机。
- 在实际使用分布式版本控制系统的时候,其实很少在两人之间的电脑上推送版本库的修改。
优点
- 和集中式版本控制系统相比,分布式版本控制系统的安全性要高很多。
- 因为每个人电脑里都有完整的版本库,某一个人的电脑坏掉了不要紧,随便从其他人那里复制一个就可以了。
- 而集中式版本控制系统的中央服务器要是出了问题,所有人都没法干活了。
- 不必联网
- 极其强大的分支管理,把SVN等远远抛在了后面。
安装GIT
- 最早Git是在Linux上开发的,很长一段时间内,Git也只能在Linux和Unix系统上跑。
- 不过,慢慢地有人把它移植到了Windows上。
- 现在,Git可以在Linux、Unix、Mac和Windows这几大平台上正常运行了。
在Windows上安装Git
下载安装
- 在Windows上使用Git,可以从Git官网直接下载安装程序,然后按默认选项安装即可。
- 除了存储位置(不要C盘)、编辑器(不要notepad),基本上都是直接默认。
- 安装完成后,在开始菜单里找到最近添加——“Git Bash”,蹦出一个类似命令行窗口的东西,就说明Git安装成功!
设置名字和邮箱
- 因为Git是分布式版本控制系统,所以,每个机器都必须自报家门:你的名字和Email地址。
- 你也许会担心,如果有人故意冒充别人怎么办?这个不必担心,首先我们相信大家都是善良无知的群众,其次,真的有冒充的也是有办法可查的。
$ git config --global user.name "Your Name"
$ git config --global user.email "email@example.com"
---------------------------
“朝着一个既定的方向去努力,就算没有天赋,在时间的积累下应该也能稍稍有点成就吧。”