Git基础知识精讲

<col id="hgghf"><thead id="hgghf"><dt id="hgghf"><embed id="hgghf"><div id="hgghf"><figure id="hgghf"></figure><sup id="hgghf"><embed id="hgghf"></embed></sup></div><code id="hgghf"><ruby id="hgghf"></ruby></code><samp id="hgghf"></samp></embed><noframes id="hgghf"><section id="hgghf"><li id="hgghf"></li><ol id="hgghf"><p id="hgghf"><blockquote id="hgghf"></blockquote></p><embed id="hgghf"></embed></ol><legend id="hgghf"></legend></section><var id="hgghf"><legend id="hgghf"></legend></var>
  • <source id="hgghf"></source>

    <cite id="hgghf"></cite>

    Git基础知识精讲

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

    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的命令。