git 基础知识精讲
    1. <code id="cbghh"><q id="cbghh"><style id="cbghh"></style><ul id="cbghh"><col id="cbghh"><dt id="cbghh"><noscript id="cbghh"><param id="cbghh"><noscript id="cbghh"></noscript><kbd id="cbghh"></kbd></param></noscript></dt></col></ul><form id="cbghh"><b id="cbghh"><textarea id="cbghh"><link id="cbghh"></link><dfn id="cbghh"><tr id="cbghh"><acronym id="cbghh"><option id="cbghh"></option></acronym></tr><object id="cbghh"><strike id="cbghh"><tbody id="cbghh"></tbody></strike><link id="cbghh"></link><canvas id="cbghh"></canvas><col id="cbghh"><caption id="cbghh"><fieldset id="cbghh"><fieldset id="cbghh"></fieldset></fieldset></caption></col><noframes id="cbghh">
    2. <bdo id="cbghh"><sup id="cbghh"><div id="cbghh"><bdo id="cbghh"></bdo></div></sup></bdo>

            git 基础知识精讲

            作者:日期:2018-05-26 19:27:14 点击:515

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