版本控制Git

一.Git是什么

版本控制工具!Git是目前世界上最先进的分布式版本控制系统(没有之一)。

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

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

二.Git发展史
cvs --svn

在2002年以前,世界各地的志愿者把源代码文件通过diff的方式发给Linus,然后由Linus本人通过手工方式合并代码!你也许会想,为什么Linus不把Linux代码放到版本控制系系统呢?不是有CVS、SVN这些免费的版本控制系统吗?因为Linus坚定地反对 CVS和SVN,这些集中式的版本控制系统不但速度慢,而且必须联网才能使用。有一些商用的版本控制系统,虽然比CVS、SVN好用,但那是付费的,和 Linux的开源精神不符。

Linus花了两周时间用C写了一个分布式版本控制系统,这就是Git!一个月之内,Linux系统的源码已经由Git管理了!Git迅速成为最流⾏的分布式版本控制系统,尤其是2008年,GitHub网站上线了,它为开源项目免费提供Git存储,无数开源项目开始迁移到GitHub,包括jQuery,PHP,Ruby等等。

三.git运行方式

1.集中式VS分布式

Linus一直痛恨的CVS及SVN都是集中式的版本控制系统,而Git是分布式版本控制

(1)集中式版本控制系统

版本库是集中存放在中央服务器的,你干活的时候,用的都是自己的电脑,所以要先从
中央服务器取得最新的版本,然后开始干 活,干完活了,再把自己的活推送给中央服
务器。中央服务器就好比是一个图书馆,你要改一本书,必须先从图书馆借出来,然后
回到家自己改,改完了,再放回图书馆。集中式版本控制系统最大的弊端就是必须联网
才能工作,如果在局域网内还好,速度够快,可如果在互联网上,遇到网速慢的话,可
能提交个10M的文件就需要5分钟,这还不得把人给憋死啊。


(2)分布式版本控制系统根本

没有“中央服务器”,每个⼈的电脑上都是一个完整的版本库,这 样,你工作的时候,
就不需要联网了,因为版本库就在你自己的电脑上。既然每个认电脑上都有个完整的版
本库,那多个人如何协作呢?比如说你在自己电脑上改 了文件A,你的同事也在他的
电脑上改了文件A,这时,你们俩之间只需把各自的修改推送给对方,就可以互相看到
对方的修改了。和集中式版本控制系统相比,分布式版本控制系统的安全性要好很多,
因为每个电脑里都有完整的版本库,某个人的电脑坏掉了不要紧,而集中式版本控制
系统的中央服务器要是出了问题,所有人都没法干活了


git运行方式如图

2.工作区和暂存区

Git和其他版本控制系统如SVN的一个不同之处就是有暂存区的概念

工作区(Working Directory):就是你在电脑⾥能看到的目录,

版本库(Repository):工作区有个隐藏目录“.git”,这个不算工作区,而是Git的版本
库,Git的版本库存了很多东西,其中最重要的就是称为stage(或者叫index)的暂存区,还
有Git为我们主动创建的第一个分支master,以及指向master的一个指针叫HEAD。

我们把文件往Git版本库中添加的时候,是分两步执行的:

第一步是用“git add”把文件添加进去,实际上就是把文件修改添加到暂存区;第二步
是用“git commit”提交更改,实际上就是把暂存区的所有内容提交到当前分支。因为
我们创建Git版本库时,Git主动为我们创建了唯一一个master分支,所以,现在,
commit就是往master分支上提交更改。你可以简单理解为,需要提交的⽂件修改通
通放到暂存区,然后,一次性提交暂存区的所有修改

安装Git 

详细看博主原文:https://blog.csdn.net/ZZQHELLO2018/article/details/82354900

 

 

你可能感兴趣的:(版本控制Git)