珠峰培训

git实用教程(一)简介

作者:

2015-11-23 11:36:13

151

Linux Torvalds1991 年创建了开源的 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的东家BitMover公司出于人道主义精神,授权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了。

参考资源

git简易教程
ProGit
廖雪峰git
git权威指南
github官方使用指南
搬进github
github flow
官方github向导

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

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

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

更要命的是,有些部分需要你的财务同事帮助填写,于是你把文件Copy到U盘里给她(也可能通过Email发送一份给她),然后,你继续修改Word文件。一天后,同事再把Word文件传给你,此时,你必须想想,发给她之后到你收到她的文件期间,你作了哪些改动,得把你的改动和她的部分合并,**真困难** 。

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

这个软件用起来就应该像这个样子,能记录每次文件的改动:

版本 用户 修改 时间

  • 1 张三 增加了用户管理功能 2015年1月3日12:14:12
  • 2 张三 删除了用户管理功能 2015年6月3日14:14:34
  • 3 李四 增加了文章管理功能 2015年8月3日18:14:54
  • 4 张三 增加了文章查询功能 2015年10月3日21:14:33

这样,你就结束了手动管理多个“版本”的史前时代,进入到版本控制的21世纪。

GIT提供以下功能

备份文件

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

记录历史

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

回到过去

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

多端共享

手机 PAD 都可以共享代码

团队协作

多人协作,处理冲突

开源协作

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

Linus一直痛恨的CVS及SVN都是 集中式 的版本控制系统,而Git是 分布式 版本控制系统,集中式和分布式版本控制系统有什么区别呢?

集中式版本控制系统

版本库是集中存放在 中央服务器 的,而干活的时候,用的都是自己的电脑,所以要先从中央服务器取得最新的版本,然后开始干活,干完活了,再把自己的活推送给中央服务器。中央服务器就好比是一个图书馆,你要改一本书,必须先从图书馆借出来,然后回到家自己改,改完了,再放回图书馆。

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

分布式版本控制系统

与集中式版本控制系统有何不同呢?首先,分布式版本控制系统根本没有 中央服务器 ,每个人的电脑上都是一个 完整的版本库 ,这样,你工作的时候,就不需要联网了,因为版本库就在你自己的电脑上。既然每个人电脑上都有一个完整的版本库,那多个人如何协作呢?比方说你在自己电脑上改了文件A,你的同事也在他的电脑上改了文件A,这时,你们俩之间只需把各自的修改推送给对方,就可以互相看到对方的修改了。

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

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

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

CVS作为最早的开源而且免费的集中式版本控制系统,直到现在还有不少人在用。由于CVS自身设计的问题,会造成提交文件不完整,版本库莫名其妙损坏的情况。同样是开源而且免费的SVN修正了CVS的一些稳定性问题,是目前用得最多的 集中式 版本库控制系统。

除了免费的外,还有收费的集中式版本控制系统,比如IBM的ClearCase(以前是Rational公司的,被IBM收购了),特点 是安装比Windows还大,运行比蜗牛还慢,能用ClearCase的一般是世界500强,他们有个共同的特点是财大气粗,或者人傻钱多。

微软自己也有一个集中式版本控制系统叫VSS,集成在Visual Studio中。由于其反人类的设计,连微软自己都不好意思用了。

分布式版本控制系统除了Git以及促使Git诞生的BitKeeper外,还有类似Git的Mercurial和Bazaar等。这些分布式版本控制系统各有特点,但最快、最简单也最流行的依然是Git!

最早Git是在Linux上开发的,很长一段时间内,Git也只能在Linux和Unix系统上跑。不过,慢慢地有人把它移植到了Windows上。现在,Git可以在Linux、Unix、Mac和Windows这几大平台上正常运行了。

一、在Windows上安装Git

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

msysgit 是Windows版的Git,从 http://git-scm.com/ 下载,然后按默认选项安装即可。

如果下载不下来可以从百度网盘 上下载 

安装完成后,在开始菜单里找到“Git”->“Git Bash”,蹦出一个类似命令行窗口的东西,就说明Git安装成功!

二、 在Mac OS X上安装Git

如果你正在使用Mac做开发,有两种安装Git的方法。

一是安装 homebrew ,然后通过homebrew安装Git。先打开网站 http://brew.sh/。 拷贝对应脚本到终端下安装homebrew.然后在终端执行 brew install git命令。

第二种方法更简单,也是推荐的方法,就是直接从 AppStore 安装Xcode,Xcode集成了Git,不过默认没有安装,你需要运行Xcode,选择菜单“Xcode”->“Preferences”,在弹出窗口中找到“Downloads”,选择“Command Line Tools”,点“Install”就可以完成安装了。

三、 在Linux上安装Git

首先,你可以试着输入git,看看系统有没有安装**Git**:

$ git
 program 'git' is currently not installed. You can install it by typing:
sudo apt-get install git

像上面的命令,有很多Linux会友好地告诉你Git没有安装,还会告诉你如何安装**Git**。

如果你碰巧用**Debian**或**Ubuntu Linux**,通过一条sudo apt-get install git就可以直接完成Git的安装,非常简单。如果想查看是否安装成功,通过git --version。

老一点的**Debian**或**Ubuntu Linux**,要把命令改为sudo apt-get install git-core,因为以前有个软件也叫GIT(GNU Interactive Tools),结果Git就只能叫git-core了。由于Git名气实在太大,后来就把GNU Interactive Tools改成gnuit,git-core正式改为git。

Fedora可以用yum

$ sudo yum install git

如果是其他Linux版本,可以直接通过源码安装。先从Git官网下载源码,然后解压,依次输入:

 ./config  
make  
sudo make install   

这几个命令安装就好了。 []

用户设置

安装完成后,还需要最后一步设置,在命令行输入:

git config --global user.name "zfpx"    
git config --global user.email "zfpx@126.com"   

因为Git是分布式版本控制系统,所以每个机器都必须自报家门:你的名字和Email地址。

注意git config命令的--global参数,用了这个参数,表示你这台机器上所有的Git仓库都会使用这个配置,当然也可以对某个仓库指定不同的用户名和Email地址。在此课程中,我们配置的环境中Git已安装好,我们课程提供也是在Linux系统中命令进行操作

参考资源