当前位置: 首页 > article >正文

版本控制器Git:时间机器与备份系统

在数字化时代,无论是编写代码还是撰写文档,版本控制已成为不可或缺的工具。想象一下,你正在创作一本小说,每天都在电脑上对其进行修改和补充。随着时间的推移,小说的内容日益丰富,结构也愈发复杂。在这个过程中,你可能会遇到一些棘手的问题:修改了一段文字后,发现之前的版本其实更好,想要恢复到之前的版本;同时在多个章节工作,每个章节都有不同的修改,希望这些修改互不干扰;与朋友合作写小说时,需要共享和同步彼此的修改。这些问题,正是版本控制系统大显身手的舞台。

一、版本控制:时间机器与备份系统

版本控制系统就像一个时间机器,它可以让你回到过去的任何时刻,查看和恢复之前的版本。同时,它也是一个备份系统,自动保存你的所有修改,确保你的工作不会丢失。对于开发者来说,版本控制系统尤为重要,因为它不仅能够帮助他们管理代码的版本,还能支持多人协同开发,提高团队的开发效率。

二、Git简介

Git可以控制电脑上所有格式的文件,如doc、excel、dwg、dgn、rvt等。对于开发者而言,Git最重要的功能是帮助管理软件开发项目中的源代码文件。

(一)Git简史

Git诞生于一个充满创新与纷争的年代。Linux内核开源项目有着众多参与者,1991-2002年间,大多数Linux内核维护工作都花在了提交补丁和保存归档的繁琐事务上。2002年,项目组开始使用专有的分布式版本控制系统BitKeeper来管理和维护代码。然而,到了2005年,开发BitKeeper的商业公司与Linux内核开源社区的合作关系结束,收回了Linux内核社区免费使用BitKeeper的权力。这迫使Linux开源社区,特别是Linux的缔造者Linus Torvalds,基于使用BitKeeper时的经验教训,开发出自己的版本系统。他们对新系统制订了若干目标:速度、简单设计、对非线性开发模式的强力支持(允许成千上万个并行开发的分支)、完全分布式以及高效管理类似Linux内核一样的超大规模项目(速度和数据量)。自2005年诞生以来,Git日益成熟完善,在高度易用的同时,仍然保留着初期设定的目标。它的速度快,极其适合管理大项目,有着令人难以置信的非线性分支管理系统。

(二)安装Git

在Linux系统中,可以通过以下命令安装Git:

yum install git

Ubuntu使用apt 

三、Git:分布式版本控制系统的代表

Git 是目前最主流的版本控制系统之一,它是一个分布式版本控制系统,这意味着每个开发者都有一个完整的代码仓库副本。与传统的中心化版本控制系统(如SVN)不同,Git 不依赖于一个中心服务器来存储所有的代码版本。在传统的中心化版本控制系统中,所有的代码都集中存放在一个巨大的书架(中心服务器)上,开发者要获取代码,必须到这个书架前,按照管理员(版本控制系统)的规定,登记借阅信息后才能拿到书籍。如果书架坏了(中心服务器故障),整个图书馆(项目开发)就陷入瘫痪,开发者无法借阅书籍,因为所有的书籍信息和借阅记录都依赖这个中心书架。

而Git的去中心化特点,让每个开发者家里都有一个小型的图书馆(本地仓库)。开发者开始工作时,会先从公共图书馆(远程仓库)借来一套完整的书籍(代码库副本)放在自己家里。即使公共图书馆暂时关闭(远程仓库出现问题),开发者依然可以在自己家里的小图书馆里查阅书籍(进行本地开发),比如添加新的笔记(提交新的代码)、整理书籍顺序(合并分支)等操作。每个开发者家里的图书馆都是独立的,有自己的借阅记录(提交历史)和书籍分类(分支结构),这些信息并不依赖于公共图书馆。

Git的分布式特点,使每个开发者的本地仓库就像分布在全国各地的分馆(分布式节点)。每个分馆都有完整的书籍副本,有自己的工作人员(开发工具)来管理书籍。开发者在本地分馆做完修改(代码编辑)后,可以通过网络将新的书籍版本(代码提交)发送到其他分馆(其他开发者的本地仓库或者远程仓库)。分馆之间可以相互交流书籍信息(代码同步),比如一个分馆有了新的珍贵书籍(重要的代码更新),其他分馆可以很方便地获取。而且,由于每个分馆都有完整的书籍体系,即使某个分馆出现问题,比如火灾(本地仓库损坏),其他分馆的书籍(代码)依然可以保证项目的完整性,可以通过从其他分馆(仓库)恢复书籍(代码)来重建受损的分馆。

四、Git仓库:图书馆与书架

Git仓库可以想象成一个图书馆,而你的项目文件夹就是图书馆中的一个书架。在这个图书馆中,每个书架(项目)都有自己的编号和位置,你可以随时找到它。

  • 书架(项目文件夹):这是你存放所有文件的地方,就像书架上摆放的书籍一样。你可以随时添加、删除或修改这些文件。
  • 图书馆管理员(Git):Git就像图书馆管理员,它记录了书架上每一本书(文件)的每一次变化。每次你修改文件并保存时,Git都会记录下这些变化,就像管理员在登记簿上记录书籍的借阅和归还情况一样。
  • 版本历史(登记簿):Git会保存一个详细的版本历史,记录了每一次提交(commit)的详细信息,包括修改了哪些文件、修改了哪些内容、谁做的修改以及修改的时间等。这就像图书馆的登记簿,你可以随时查阅。

五、Git的核心操作

(一)提交(Commit):拍照留念

每次你完成一些工作并希望保存当前状态时,你就会进行一次提交(commit)。这就像给你的项目拍一张照片,记录下当前的状态。每次提交都会生成一个唯一的标识符(commit ID),就像照片的编号一样,你可以通过这个编号找到特定的版本。

(二)分支(Branch):平行宇宙

想象你正在写小说的第5章,但你突然有了一个新想法,想尝试写一个不同的结局。你不想影响当前的主线故事,也不想放弃这个新想法。这时,你可以创建一个分支(branch)。分支就像是一个平行宇宙,你可以在其中自由地进行实验和修改,而不会影响主宇宙(主分支)。当你对新分支的修改满意后,你可以将这些修改合并回主分支,就像将平行宇宙中的故事合并回主线故事一样。

(三)合并(Merge):故事融合

当你在分支中完成了修改,想要将这些修改应用到主分支时,你就可以进行合并(merge)。这就像将两个故事融合在一起,Git会自动处理大部分的合并工作,但有时也会需要你手动解决一些冲突。

(四)远程仓库(Remote Repository):云端图书馆

除了本地的图书馆(本地仓库),还有一个云端图书馆(远程仓库)。这个云端图书馆可以让你和你的朋友共享和同步你们的修改。你可以将你的修改推送到云端(push),也可以从云端获取别人的修改(pull)。

六、基于Git的平台:Gitee与GitHub

Gitee和GitHub是基于Git的网站平台,它们为开发者提供了丰富的功能和服务。通过这些平台,开发者可以方便地管理自己的代码仓库,与他人协作开发项目。在这些平台上,可以创建新的仓库、克隆现有仓库、提交代码、创建和管理分支、合并代码等。同时,它们还提供了代码审查、持续集成、项目管理等多种工具,极大地提高了开发效率和团队协作的便利性。

(一)在GitHub创建项目

  1. 注册账号:注册GitHub账号比较简单,按照官网提示进行操作即可,需要进行邮箱校验。
  2. 创建项目
    • 登录成功后,进入个人主页,点击左下方的New repository按钮新建项目。
    • 在跳转到的新页面中输入项目名称(注意名称不能重复,系统会自动校验,校验过程可能会花费几秒钟)。校验完毕后,点击下方的Create repository按钮确认创建。
    • 在创建好的项目页面中复制项目的链接,以备接下来进行下载。
  3. 下载项目到本地
    • 创建好放置代码的目录后,使用以下命令下载项目:
      git clone [url]
      这里的url就是刚刚创建好的项目的链接。

我们拉取创建好本地仓库后,我们进入clone后形成的目录,"ll"发现有一个.git的目录,这个才是我们真正意义上的当前我们新建的仓库,将.git称为隐藏的本地仓库:

我们可以tree一下.git:他会包含我们历史上所有的修改记录。(这里简单讲解而已)

与上面的提交的形象讲解,有本质理解的区别:Git是一个分布式版本控制系统,它通过记录文件的变化来管理项目的版本。当你进行一次提交(commit)时,Git只会提交自上次提交以来发生变化的部分。这一特性使得Git的提交操作既高效又节省空间

就举例当前我有100行代码,提交后我发现有一行代码重复了,我将其行删除,假设删除的是第100行,在.git里记录的不是将总100行的代码和改后总99行的代码全部保存起来,而是在提交的时候,只需要记录"删除100"类似这样的字符串,并且将删除的第100行的内容也拼接在后面,以后需要找回的话,只需要将"删除",改成"添加",经过反向操作就可以将源代码寻回了。

我们当前目录就是我们的工作区:

如果我们在当前目录下了touch的test.c文件,并且vim文件,进行了编辑,然而在当前工作区的test.c源代码并没有添加到.git的本地仓库中,那我们因该如何将其源代码放到仓库中,我们看看以下的git的基本操作。

(二)Git基本操作

  • git add

    • 将代码放到刚才下载好的目录中,使用以下命令将需要git管理的文件告知git:
      git add [文件名]  #git add test.c
      
      git add .        #默认把当前目录下的所有文件全部添加到.git仓库当中

但是目前含不算真正的把test.c文件放到仓库中,而是将其暂时放在了暂存区里面:

那么暂存区又有什么用呢?

可以将多个需要提交的文件先统一存到一起,然后进行一次的提交;

而且暂存区的的文件可以提前取消上传。

我们可以通过:

git status

获取当前git状态:

接下来:一次提交到本地 

  • git commit

    • 提交改动到本地,使用以下命令:
      git commit -m "XXX"
      最后的“.”表示当前目录。提交时应注明提交日志,描述改动的详细内容。(-m就是提交日志信息:不可以乱写,比如:修正了野指针问题,修正了异常处理问题......)

我们发现:

首次使用git,git会要求我们输入username,email。

我们就应该在命令行输入对应的信息:(按照提示,只需要将""内的内容改为对应的信息)

要将与所注册的github/gitee的邮箱/用户名一致:

因为git会记录提交记录,提交的日志信息不可以乱写,通过:

git log

可以查看我们的提交记录。

  • git push

    • 同步到远端服务器上,使用以下命令:
      git push
      需要填入用户名账号和密码。同步成功后,刷新GitHub页面就能看到代码改动了。

注意:git版本管理,只进行管理源文件(.h/.c/.cpp) 

(三)配置免密码提交

参考CSDN博客文章:git本地免密码和账号pull、push_没有git账号怎么拉代码-CSDN博客

(四)其他操作

  • git log:查看提交日志。
  • git status:查看当前仓库状态。
  • git pull:从远程仓库拉取最新代码。(也就是刷新页面,避免冲突:远端仓库和本地仓库做了一次同步)(rejected!)
  • .gitignore配置忽略文件,避免不必要的文件被git跟踪。(进行本地文件后缀过滤的)

我们可以vim .gitignore文件,在里面编辑内容,可以过滤相关后缀的文件,在上传到仓库的时候可以忽略,不进行上传:

我们是可以将仓库代码拉取到Windows当中:假设我们Windows上有安装小乌龟,也可以通过该工具,clone远端仓库的地址,实现远端仓库内容拉取到本地仓库(文件夹):

六、总结

版本控制系统(如Git)就像一个时间机器和备份系统,帮助你管理项目的每一个版本。Git仓库是一个图书馆,记录了你的项目文件夹(书架)的每一次变化。通过提交(拍照留念)、分支(平行宇宙)和合并(故事融合),你可以灵活地管理你的项目,确保你的工作安全且易于协作。远程仓库则让你可以与他人共享和同步你的项目,就像一个云端图书馆一样。Gitee和GitHub等基于Git的平台,更是为开发者提供了强大的支持,让版本控制和团队协作更加高效便捷。


http://www.kler.cn/a/503106.html

相关文章:

  • Zookeeper(3)Zookeeper的工作原理是什么?
  • HTTP详解——HTTP基础
  • 14X505-1《火灾自动报警系统设计规范图示》中相关数据和总线制的个人理解
  • 《AI赋能鸿蒙Next,开启智能关卡设计新时代》
  • 无需昂贵GPU:本地部署开源AI项目LocalAI在消费级硬件上运行大模型
  • 服务器数据恢复—raid5故障导致上层ORACLE无法启动的数据恢复案例
  • ASP.NET Core与GraphQL集成
  • Excel数据叠加生成新DataFrame:操作指南与案例
  • ubuntu22.4 ROS2 安装gazebo(环境变量配置)
  • Jira用例自动去除summary重复用例
  • Android 概述
  • [OPEN SQL] 限定选择行数
  • 学习记录-责任链模式验证参数
  • opencv进行人脸识别环境搭建
  • 探索Java爬虫:获取淘宝App商品详情原数据API接口的实现
  • ARCGIS三维模型及动画模拟
  • 性能测试工具Jmeter中的FTP脚本开发
  • django在线考试系统
  • Blazor程序系统终端用户加载和运行方式研究
  • 如何系统学习一门it技术
  • MFC界面库ToolkitPro v15.3.1的编译和使用教程(支持VS2015和VS2017)
  • 32单片机从入门到精通之测试与验证——单元测试(十五)
  • Git提交失败【File[xxxxxx] size xxxMB, exceeds quota 100MB】
  • vue.js 基于VueCli自定义创建项目
  • CTFshow—文件包含
  • Kotlin 快速上手指南:从安装 IntelliJ IDEA 到编写第一个程序