CVS/SVN

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

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

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

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

GIT

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

区别

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

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

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

git learn

创建版本库

初始化一个Git仓库

使用```git init```命令。

添加文件到Git仓库,分两步:

1.使用命令git add<file>,注意,可反复多次使用,添加多个文件;
2.使用命令git commit -m <message>,完成。
git commit命令,-m后面输入的是本次提交的说明,可以输入任意内容,当然最好是有意义的,这样你就能从历史记录里方便地找到改动记录。

查看工作区的状态

使用git status命令。

如果git status告诉你有文件被修改过,用git diff可以查看修改内容。

回退版本相关命令

HEAD指向的版本就是当前版本,因此,Git允许我们在版本的历史之间穿梭,使用命令git reset --hard commit_id(head^)
另一种写法也可以像下面一样
上一个版本就是HEAD^,上上一个版本就是HEAD^^,当然往上100个版本写100个^比较容易数不过来,所以写成HEAD~100,命令就是 git reset --hard head~100

穿梭前,用git log可以查看提交历史,以便确定要回退到哪个版本。

要重返未来,用git reflog查看命令历史,以便确定要回到未来的哪个版本。

转载于:https://www.cnblogs.com/benjaminfee/p/10187951.html

CVS/SVN/GIT相关推荐

  1. 版本控制概述|VSS/CVS/SVN/Git比较|Windows下SVN搭建详细介绍

    版本控制介绍 常用版本控制技术 vssVisual SourceSafe cvsConcurrent Versions System svnSubversion git 区别转自网络 SVN使用简介 ...

  2. 【版本工具】cvs,svn,git等版本工具区别

    ##1. 什么是版本控制工具 来自维基百科:版本控制是维护工程蓝图的标准作法,能追踪工程蓝图从诞生到定案的过程. 此外,版本控制也是一种软件工程技巧,借此能在软件开发中,确保由不同人所编辑的同一代码文 ...

  3. CVS,GIT,Mercurial和SVN比较

    最近关于DVCS讨论的如火如荼,转一篇4个著名VCS的比较 特征 CVS Git Mercurial Subversion 是否原子提交 CVS: 没有. CVS提交不是原子的 Git: 是的. 提交 ...

  4. phpstrom配置svn/git提交

    在setting选项Version Control中选择Subversion,正确配置SVN/Git的命令行路径,比如我的Git路径:F:Program FilesGitbingit.exe 将当前目 ...

  5. CVS/SVN 托管服务

    软件工程中,代码版本管理是必要的一个环节. 如果觉得自己假设一个CVS / SVN 服务器太麻烦,不妨试试托管服务. 这个网站  http://cvsdude.com  的服务据说还不错. 如果你的软 ...

  6. python svn模块_使用Python实现一键批量更新SVN/Git模块的脚本

    现在我们开发的过程中,大都是模块化的工作方式,咱们的工程源码结构就是N个模块,N个SVN/Git地址,如果需要更新就得手动一个个的操作,弄起来实在太麻烦了,之前我都是写批处理来实现批量更新的,现在来使 ...

  7. VSS SVN GIT SVN 加锁签出

    VSS TFS SVN GIT VSS 两大功能: 1.签出后加锁,别人不能签出,独占签出. 2.在服务端可以查看哪些用户签出了哪些文件. 3.查看所有签出未签入的文件列表,SVN未发现此功能. 缺点 ...

  8. jenkins svn/git sonarqube scanner 代码集成测试

    大家好,我是烤鸭: 今天分享一个代码检测工具sonar,在jenkins集成的时候使用. 环境: sonarqube 7.1 jenkins 2.12x sonarqube scanner (官网最新 ...

  9. tar命令打包压缩时排除.svn .git .repo等特定文件/文件夹报错/未生效

    tar命令打包压缩时排除.svn .git .repo等特定文件/文件夹报错/未生效 当使用tar命令打包压缩的同时期望排除某类文件或文件夹时,可以使用--exclude参数. 在ubuntu20.0 ...

最新文章

  1. 损失函数理解汇总,结合PyTorch1.7和TensorFlow2
  2. 雷林鹏分享:Lua 错误处理
  3. 【Android-tips】 Unable to execute dex: Multiple dex files define 解决方法
  4. 一个简单词法分析器的实现代码(java实现)
  5. 信息收集——Office钓鱼
  6. 动手实现一个适用于.NET Core 的诊断工具
  7. css3动画animation,transition
  8. 阿里云专家赵伟教你在CDN边缘节点上构建多层纵深防护体系
  9. java 集成 kafka 0.8.2.1 适配jdk1.6
  10. 前端笔记 | CSS浮动
  11. 3000计算机组装电脑,电脑组装教程,教您组装电脑配置清单
  12. adb 查看屏幕大小_Android adb获取屏幕分辨率
  13. 蓝桥杯每日一题(22):三升序列(python)
  14. 指尖检测的新方法几种
  15. IBM云对象存储 - Linux主机通过rclone和COS API上传大文件
  16. 10nm首秀!这就是英特尔十代酷睿
  17. 虚拟主机如何清空网站程序文件和mysql数据库数据
  18. java中 ^ 是什么意思
  19. TooManyCells:用于识别与可视化单细胞关系的方法
  20. 超大文件下载神器(Internet Download manager) IDM

热门文章

  1. 软件测试面试技巧|项目常识篇
  2. web前端新人第一课:html基础知识,你能学会吗?
  3. java struts2 xss_Apache Struts2提供的最新demo中几处XSS(不严谨啊!不严谨啊!)
  4. java int 指针_如何在Java中使用指针?
  5. 命令行参数python sys模块_python教程--sys模块--命令行参数
  6. 2017计算机湖北对口试题答案,2017年计算机专业对口考试试卷及答案
  7. 计算机专业基础融合,【计算机专业论文】计算机专业产教融合转型发展模式探析(共2546字)...
  8. php socket 小程序,实例详解微信小程序如何使用Socket
  9. CentOS上的安装和配置MYSQL 支持 INNODB引擎
  10. 先序abdfcegh 中序bfdagehc 后序线索二叉树_二叉树的遍历和线索二叉树