Git——版本控制概论(一)
随着信息技术的发展,软件开发已不是小手工作坊,软件的规模和复杂度已经不再适合一个人单打独斗的开发了,
团队协作变得相当重要,如果没有VCS(版本控制系统Version Control System),团队开发就会变得乱七八糟。
1.版本控制概论
版本控制是记录我们对文件、目录或工程等修改的历史,方便查看更改历史,备份以便恢复以前的版本,多人协作。
最早的版本控制是纯手工的版本控制:修改文件,保存文件副本。
由于许多时候偷懒省事,保存副本文件名比较随意,时间一长就不知道哪个是哪个了。
由于手工管理比较麻烦且混乱,后来就出现了本地版本控制,记录文件每次的更新,可以对每个版本做一个快照,或是记录补丁文件。
但是本地版本控制系统偏向于个人使用,或者多个使用的人必须使用相同的设备,如果需要多人协作那就不好办了。
于是乎,集中版本控制(Centralized Version Control Systems,简称CVCS)应运而生。
在CVCS中,所有版本数据都保存在服务器上,一起工作的人从服务器上同步更新或上传自己的修改。
但是,所有版本数据都保存在服务器上,用户要获取最新版本就需要从中心服务器上下载,如果网络的带宽高还好,否则会非常麻烦。
同时查看历史版本也必须联网,如果不联网就看不到历史版本,无法切换版本验证问题,或不能在不同分支工作。
而且,所有数据都保存在一台服务器上,数据面临丢失的风险。
针对CVSC的以上缺点,就出现了分布式的版本控制(Distributed Verson Control System,简称DVCS),常用的有Git、Mercurial等。
DVCS不是复制指定版本的快照,而是把所有的版本信息仓库全部同步到本地,这样就可以在本地查看所有的历史版本,
可以离线在本地提交,只需要在联网时推送到相应的服务器或其它用户那里。
由于每个用户那里保存的都是所有的版本数据,所以只要一个用户的设备没有问题就可以恢复所有数据。
当然,这增加了本地存储空间的占用。
2.集中式VS分布式
由于在实际生产中基本上都是使用集中式或分布式的版本控制,所以下面会分析一下各自的优缺点。
(1)集中式版本控制系统
集中式的版本控制系统的版本库是集中存放在中央服务器,而干活的时候,用的都是自己的电脑,
所以先要从中央服务器取得最新的版本,然后开始干活,干完活后,再把自己的或推送个中央服务器。
中央服务器就好比一个图书馆,你要改一本书,必须先从图书馆借出来,然后回到家中改,改完之后再放回图书馆。
集中式版本控制最大的毛病就是必须联网才能工作,没有网你什么都做不了,而且受制于带宽。
(2)分布式版本控制
与集中式版本控制相比,分布式版本控制没有“中央服务器”,每个成员的电脑都是一个完整的版本库,
这样你工作的时候就不需要联网,因为版本库就在你自己的电脑上。那么多人是如何协作的了?
如果你修改了一个文件A,你的同时也修改了一个文件A,那么你俩之间就可以相互推送,然后决定最终的版本。
还集中式版本系统相比,分布式版本系统的安全性要高的多,因为每个人都有一个完整的库,所以某个人的电脑出了问题不打紧,
只要从别人那里复制一份就行了,而集中式的版本控制系统要是“中央服务器”出了问题,那就彻底玩完。
在实际使用分布式版本控制系统的时候,大部分时候对于两个人来说可能不在一个局域网之内,
这样两台电脑就不能直接访问,或者说双方并不是同时在线,以及其他种种原因,因此在分布式系统中需要有一台服务器充当“中央服务器”,
但是只是方便不同库之间的版本推送,没有它也能工作。
当然,我们接下来要详细介绍的Git并不是说只有不必联网这么简单。
CVS作为最早的开源而且免费的集中式版本控制系统,直到现在依然还有不少人在使用。
由于CVS自身设计的问题,会造成提交文件不完整,版本库莫名其妙损坏的情况。
同样是开源而且免费的SVN修正了CVS的一些稳定性问题,是目前使用最多的集中式版本控制系统。
Git是一种非常流行的分布式版本控制系统,也可以叫做源代码管理系统,相对于SVN来说就是分布式。
SVN需要一个中心服务器保存源代码,所有的开发者都是用客户端进而这个服务器交互。
GIt的强大之处并非在于分布式,而是其对源代码存储的机制(使用快照),
由于这样的机制的存在,你可以大量频繁的使用分支来工作,通过分支来隔离功能开发的过程。
Git——版本控制概论(一)的更多相关文章
- GIT 版本控制常用命令学习汇总
GIT 版本控制常用命令汇总 git version 查看当前git版本信息 git help 获取全部命令帮助信息 git help <command> 获取指定命令帮助信息 git c ...
- Git版本控制与工作流
基本概念 Git是什么? Git是分布式版本控制系统,与SVN类似的集中化版本控制系统相比,集中化版本控制系统虽然能够令多个团队成员一起协作开发,但有时如果中央服务器宕机的话,谁也无法在宕机期间提交更 ...
- Git版本控制教程
Git 版本控制入门 不了解Git请查看权威Git书籍 ProGit(中文版). 一份很好的 Git 入门教程,点击这里查看. Git客户端下载地址: 官方Git - TortoiseGit - So ...
- Git版本控制工具(三)----远程仓库GitHub的使用
[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...
- git版本控制工具(二)----本地版本库的常用操作
[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/ ...
- Git版本控制工具(一)----git的安装及创建版本库
[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/ ...
- Git 版本控制工具(学习笔记)
GIT(分布式) 一.Git 初始版本控制工具 1. 安装Git Ubuntu系统下,打开shell界面,输入: sudo apt-get install git-core 之后回车输入密码,即可完 ...
- Git版本控制与工作流详解
这篇文章是针对git版本控制和工作流的总结,如果有些朋友之前还没使用过git,对git的基本概念和命令不是很熟悉,可以从以下基本教程入手: 专为设计师而写的GitHub快速入门教程 git – 简明指 ...
- Git版本控制,rsync同步文件,完成线上部署
之前项目开发完成,测试阶段,借着此时,由于公司暂时用两台aliyun ecs 做业务层,所以每次都需要同步线上文件,进而想着搞一搞服务器端(小公司,新项目,先小搞一把),搭建一套小的版本控制上线的 ...
随机推荐
- SQLite升级数据库:
SQLiteOpenHelper子类关键代码: SQLite升级数据库: SQLiteOpenHelper子类关键代码: public class MyDataHelper extends SQLit ...
- cordova与ios native code交互的原理
非常早曾经写了一篇博客,总结cordova插件怎么调用到原生代码:cordova调用过程,只是写得太水.基本没有提到原理.近期加深了一点理解,又一次补充说明一下 js调用native 以下是我们产品中 ...
- Android 热修复使用Gradle Plugin1.5改造Nuwa插件
随着谷歌的Gradle插件版本号的不断升级,Gradle插件如今最新的已经到了2.1.0-beta1,相应的依赖为com.android.tools.build:gradle:2.0.0-beta6, ...
- Android--Handler的用法:在子线程中更新界面
本文主要介绍Android的Handler的用法.Handler能够发送Messsage和Runnable对象到与其相关联的线程的消息队列. 每一个Handler对象与创建它的线程相关联.而且每一个H ...
- 【SpringMVC学习03】SpringMVC中注解和非注解方式下的映射器和适配器总结
从上一篇的springmvc入门中已经看到,springmvc.xml中的配置了映射器和适配器,是使用非注解的方式来配置的,这是非注解方式的一种,这里再复习一下: 1. 非注解方式 1.1 处理器适配 ...
- Effective JavaScript Item 10 避免使用with
本系列作为Effective JavaScript的读书笔记. Item 9:避免使用withkeyword 重点: 设计withkeyword本来是为了让代码变简洁,可是却起到了相反的效果.比方: ...
- atom无法安装插件的解决方法
atom通过setting中无法下载插件,通过apm也无法下载插件,可能是网络.config配置的问题,不好解决. 下面的方法全手动,基本属于万金油方法: 1,在atom的setting页面中点击op ...
- CoreAnimation的使用小结
參考:http://www.cnblogs.com/wendingding/p/3801157.htmlhttp://www.cnblogs.com/wendingding/p/3802830.htm ...
- PHP高级工程师的要求
PHP 高级工程师1名,(3年以上工作经验 ) 1.熟悉unix环境编程,如多线程/多进程,IO复用.锁.定时器.新号.信号量.共享内存.消息队列.文件系统2.熟悉php的stream.sock ...
- json字符串传值到后台出现乱码的问题的解决方法
1.原因:前台的编码是ISO-8859-1,后台的编码是UTF-8,所以会冲突 2.解决方法:先用ISO-8859-1解码成字节数组,再转成UTF-8编码格式 String strw = new St ...