【Git系列】了解什么是版本控制


【其他系列】Git最详细的体系化教程

学习git之前,我们需要先明白一个概念,版本控制!

🧊1. 什么是版本控制

​ 版本控制(Revision control)是一种软件工程技术,用于管理开发过程中对文件、目录或工程等内容的修改历史,以便查看更改历史记录并恢复以前的版本。

简单说就是用于管理多人协同开发项目的技术。

​ 举个例子,假设你正在开发一个网站,你和你的团队成员都在修改网站的代码。在没有版本控制的情况下,如果你想回到之前的版本,你需要手动保存每个版本的副本。这样做不仅容易出错,而且难以管理。但是,如果你使用版本控制系统,它会自动为你保存每次提交的快照。这样,如果你想回到之前的版本,只需在版本控制系统中选择相应的版本即可。此外,版本控制系统还可以帮助你查看每个版本之间的差异,并帮助你解决代码冲突。

🧊2. 为什么要有版本控制

版本控制非常重要,因为它可以帮助开发人员更好地管理他们的代码。以下是一些使用版本控制的好处:

  • 备份和恢复:版本控制系统会自动保存每次提交的快照,因此你可以随时回到之前的版本。
  • 协作:版本控制系统可以帮助多个开发人员协同工作,解决代码冲突。
  • 追踪更改:版本控制系统可以帮助你查看每个版本之间的差异,了解谁更改了什么。
  • 测试和调试:使用版本控制系统,你可以轻松地切换到不同的版本,以便测试和调试。

总之,版本控制可以帮助开发人员更好地管理他们的代码,提高开发效率。

🧊3. 常见的版本控制工具

主流的版本控制器
Git是一个分布式版本控制系统,最初由 Linus Torvalds 开发,用于管理 Linux 内核开发。
SVN(Subversion)是一个集中式版本控制系统,由 CollabNet 开发

除了 GitSVN 之外,还有一些其他的版本控制器,例如 MercurialBazaarDarcs 等。这些版本控制器都有各自的特点和优势,可以根据项目需求选择合适的版本控制器。

🧊4. 版本控制分类

🪟4.1 本地版本控制

  本地版本控制系统是一种早期的版本控制方法,它在本地计算机上保存文件的历史版本。在没有使用版本控制的适合,大多数人习惯用复制整个项目目录的方式来保存不同的版本,或许还会改名加上备份时间以示区别。这么做唯一的好处就是简单,但是特别容易犯错。有时候会混淆所在的工作目录,一不小心会写错文件或者覆盖意想外的文件。

  为了解决这个问题,人们很久以前就开发了许多种本地版本控制系统,大多都是采用某种简单的数据库来记录文件的历次更新差异。其中最流行的一种叫做 RCS,现今许多计算机系统上都还看得到它的踪影。RCS 的工作原理是在硬盘上保存补丁集(补丁是指文件修订前后的变化);通过应用所有的补丁,可以重新计算出各个版本的文件内容。

请添加图片描述

  然而,随着项目规模和协作人数的增加,本地版本控制系统很难满足需求。因此,人们开发了集中式分布式版本控制系统来解决这些问题。

🪟4.2 集中版本控制

集中式版本控制是一种使用中央服务器来管理代码版本和备份的系统。所有的用户都需要从中央服务器获取或提交代码,这样可以方便地协同工作和控制权限,但也需要依赖网络环境和中央服务器的稳定性。

代表产品:SVNCVSVSS

img

  假设你和你的同事都在开发一个网站项目,你们使用 SVN(Subversion)这个集中式版本控制系统来管理代码。你们的代码都存放在一个中央服务器上,每次你想要修改或添加代码,你就需要从服务器上下载最新的版本,然后在本地编辑,再上传到服务器上。这样,你就可以保证你的代码和你的同事的代码是一致的,而且服务器上有所有的历史记录,方便追踪和回滚。这就是一个集中式版本控制。

  这种做法带来了许多好处,特别是相较于老式的本地版本控制系统来说。现在,每个人都可以在一定程度上看到项目中的其他人正在做些什么。而管理员也可以轻松掌控每个开发者的权限,并且管理一个 CVCS 要远比在各个客户端上维护本地数据库来得轻松容易。

  然而,这种做法也有一些缺点。最显而易见的缺点是中央服务器的单点故障。如果宕机一小时,那么在这一小时内,谁都无法提交更新,也就无法协同工作。如果中心数据库所在的磁盘发生损坏,又没有做恰当备份,毫无疑问你将丢失所有数据——包括项目的整个变更历史,只剩下人们在各自机器上保留的单独快照。

🪟4.3 分布式版本控制

  分布式版本控制允许多个开发者在本地分别拥有一个完整的代码库,而不是像集中式版本控制那样,所有开发者都需要连接到同一个中央代码库。这意味着开发者可以在本地进行版本控制操作,而不必依赖于中央服务器。相当于中央服务器和本地都有一个版本控制系统,开发过程中两者不冲突也不依赖。

  常见的分布式版本控制有Git,是目前世界上最先进的分布式版本控制系统之一。它可以让每个人都可以创建一个独立的代码仓库用于管理,各种版本控制的操作都可以在本地完成。

img

  假如两个同事对同一个项目进行开发,本地都安装了一个Git,这时他们甚至不必连接到中央服务器,在没有网络连接的情况下进行版本控制操作,张三开发A功能,李四开发B功能,开发完后他俩同时推给中央服务器的版本控制系统,此时张三和李四都能从中央服务器拉取对方的代码并在本地合并,即使中央服务器损坏,他们本地都包含项目的整个变更历史,解决集中式版本控制丢失所有数据的缺点,而这里的中央服务器的作用可以理解为方便大家交换和修改。


请添加图片描述

一、了解什么是版本控制

二、Git概述

三、Git下载与安装教程

四、Git相关命令

五、Git分支操作

六、Git到远程仓库

七、Git配置SSH免密登录

八、IDEA集成Git


  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

虎哥@

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值