Git分布式管理-头歌实验日志和版本回退

Git使用过程中,一种很常见的情况是:发现某个已经提交到仓库里的代码文件有致命的bug,必须将代码回滚到上一个版本,在这种情况下就显示出了Git的强大。Git为每次提交,都保留了日志,根据提交日志,Git可以方便地进行版本回退。本实训通过介绍Git日志相关知识和操作,使大家掌握Git版本回退相关内容。

一、回到前一次提交  git revert

任务描述

如果提交到本地仓库中的代码发现了bug,就必须将代码回到上一个版本。而在Git中,一次提交就对应着一个版本,因此可以根据日志信息进行版本回退。

本关任务:将本地仓库回退到上一个版本。

相关知识
强大的git log

在之前,我们已经介绍了git log的基本使用方法,这里我们要进一步介绍git log的使用。

  • 查看提交的内容差异 git log提供了-p参数,用于查看每次提交之间的内容差异,如下:   git log -p 即可显示每次提交之间的变化:
  • 而如果想限制显示的范围,则可以再添加参数用于限定:   
    git log -p -2 
    如上,则仅显示最近的两次更新。 如上所示,这一选项附带了每次commit的内容变化,这就为代码审查或者浏览某个搭档的修改内容,提供了很好的参考。
  • 其他git log选项:

    1. 单词层面对比 Git提供了--word-diff选项,可以显示单词层面的差异。当需要在书籍、论文这种很大的文本文件上,进行对比的时候,这个功能就非常有用。

    2. 显示简要的增改行数 Git提供了--stat选项,则可以仅显示增加或者减少了多少行。

    3. pretty选项 使用--pretty 选项选项,可以指定不同的显示属性,如oneline 将每个提交放在一行显示。 shortfullfuller 可以指定展示的信息的多少。

git revert实现版本回退

版本回退可以用git revert命令。git revert撤销提交时,会保留所撤销的提交的记录和历史,并将撤销操作做为一次新的提交。即提交一个新的版本,将需要revert的版本的内容再反向修改回去,版本会递增,不影响之前提交的内容。其具体的使用方法如下:

git reset实现版本回退

git reset也能实现版本回退,但是git revertgit reset也存在一定的区别 :

  • git revert是用一次新的commit来回滚之前的commitgit reset是直接删除指定的commit
  • 在回滚这一操作上看,效果差不多。但是,在日后继续merge以前的老版本时有区别。因为git revert是用一次逆向的commit,“中和”之前的提交,因此日后合并老的branch时,导致这部分改变不会再次出现。但是git reset是把某些commit在某个branch上删除,因而和老的branch再次merge时,这些被回滚的commit应该还会被引入;
  • git reset 是把HEAD向后移动了一下,而git revertHEAD继续前进,只是新的commit的内容和要revert的内容正好相反,能够抵消要被revert的内容。

git reset用法如下:

  • git reset HEAD 回到前一次 commit。也可以用于将错误的文件添加进暂存区后,想回退取消,如:   git reset HEAD 文件名
  • git reset HEAD^ 回到前前一次 commit
  • git reset commit 比如:commit = fa042ce57ebbe5b,回到指定的版本,撤销也会作为一次提交进行保存。

另外git reset也可以指定reset的模式:hardsoftmixedmergedkeep。 这几种模式的差别如下:

  • --soft 缓存区和工作目录都不会被改变;
  • --mixed – 默认选项。缓存区和你指定的提交同步,但工作目录不受影响;
  • --hard – 缓存区和工作目录,都同步到你指定的提交。

几种模式的具体使用方法如下:

#直接丢弃工作区和暂存区的修改
git reset --hard HEAD
#暂存区内容保留,工作区修改丢弃
git reset --mixed HEAD
#暂存区和工作区内容都保留
git reset --soft HEAD
编程要求

平台已准备了本地仓库gitTraining,并在master分支进行了三次提交:

  • 第一次提交:添加了helloGit1
  • 第二次提交:添加了helloGit2
  • 第三次提交:添加了helloGit3

现在发现,helloGit3内容有错误,需要撤销第三次提交,即将HEAD指向第二次提交。 本关的编程任务是,补全右侧代码片段中BeginEnd中间的脚本,撤销最近一次提交。

#进入gitTraining
cd gitTraining

#请在下方Begin至End星号线内填写git命令以撤销最近一次提交
#********** Begin **********#

#git reset --hard HEAD~1
git revert HEAD 
#********** End **********#

 

 二、回到指定提交

编程要求

平台已准备了本地仓库gitTraining,并在master分支进行了三次提交:

  • 第一次提交:添加了helloGit1
  • 第二次提交:添加了helloGit2
  • 第三次提交:添加了helloGit3

现在发现,helloGit3helloGit2内容均有错误,需要撤销第三次、第二次提交。即将HEAD指向第一次提交。 本关的编程任务是,补全右侧代码片段中BeginEnd中间的脚本,撤销最近两次提交,以回到第一次提交,即将HEAD指向第一次提交,需要选择--hard模式。

#进入gitTraining
cd gitTraining

#请在下方Begin至End星号线内填写git命令以回到第一次提交的版本
#********** Begin **********#

git reset --hard HEAD~2
#********** End **********#

`git reset --hard HEAD~2` **命令用于将当前分支回退到上一个提交(commit),同时清除工作目录和暂存区的改动**。

该命令由三部分组成:

1. `git reset`: 这是Git的一个基本命令,用来重置当前分支的HEAD指针以及工作目录和暂存区的状态。
2. `--hard`: 这个选项告诉Git不仅要移动HEAD指针,还要清除所有相关的改动,包括工作目录和暂存区的更改。
3. `HEAD~2`: 这里的`HEAD`代表当前分支最新的提交,而`~2`表示要回退到当前提交的前两个版本,即祖父级提交。

使用这个命令时需要非常小心,因为它会丢弃自指定提交之后的所有工作成果,包括未提交的修改和新增的文件。如果确定要执行这样的操作,建议先备份重要的工作内容,以防万一。

#进入gitTraining
cd gitTraining

#请在下方Begin至End星号线内填写git命令以回到第一次提交的版本
#********** Begin **********#
git revert HEAD~2..HEAD
#git reset --hard HEAD~2
#********** End **********#

 `git revert HEAD~2..HEAD` **命令用于撤销当前分支中最近两个提交的更改**。

该命令由两部分组成:

1. `git revert`: 这是Git的一个基本命令,用来创建一个新的提交,该提交会撤销指定范围内的提交的更改。
2. `HEAD~2..HEAD`: 这里的`HEAD`代表当前分支最新的提交,而`~2`表示要回退到当前提交的前两个版本,即祖父级提交。`..`表示范围,所以`HEAD~2..HEAD`表示从祖父级提交到当前提交的范围。

使用这个命令时,Git会自动生成一个新的提交,该提交会撤销指定范围内所有提交的更改。这样做的好处是保留历史记录,并且不会对工作目录和暂存区产生任何影响。但是,如果需要撤销的提交非常多,那么执行这个命令可能会比较耗时。

三、 撤销修改

任务描述

在本地开发中,经常遇到的一个问题是:对一个文件的修改有错误,需要丢弃修改。如何准确地丢弃指定的修改,是一个关键的操作。

本关任务:撤销本地的修改。

相关知识
git reset实现版本回退

当将有错误的文件add进暂存区后,可以使用git reset丢弃修改。即:

git reset HEAD 文件名

但此时修改仍旧保留在工作区。

如果尚未add进暂存区,则可以使用:

 git reset --hard HEAD

这样就能彻底丢弃修改,即将修改从暂存区及工作区彻底删除。 #####git checkout丢弃修改 当将错误的文件add进暂存区后,使用git checkout无法将修改从暂存区中撤销,必须要先使用git reset将修改从暂存区中撤销。

git checkout丢弃修改

当将错误的文件add进暂存区后,使用git checkout无法将修改从暂存区中撤销,必须要先使用git reset将修改从暂存区中撤销。

git chekcout -- hello

通过这种方式,就可将hello文件自上个commit之后,尚未add进暂存区的修改丢弃。

编程要求

平台已为你准备了本地仓库gitTraining,并在master分支进行了一次提交,将文件helloGit提交到了本地仓库。随后,平台又对helloGit进行了修改,但是尚未添加(即add)到暂存区。现在发现此修改有错误需要丢弃。

本关的编程任务是,补全右侧代码片段中BeginEnd中间的脚本,丢弃helloGit中尚未添加到暂存区的修改。

#进入gitTraining
cd gitTraining

#请在下方Begin至End星号线内填写git命令以丢弃helloGit的修改
#********** Begin **********#

#git checkout -- helloGit
git reset --hard HEAD
#********** End **********#

四、删除文件

任务描述

Git使用过程中,涉及到撤回的操作,还有从暂存区或者分支删除文件。比如你错误地将测试过程中产生的日志文件提交到了暂存区或者分支上面去了,那么你可能就需要删除文件。

本关任务:彻底删除本地仓库中某个文件。

相关知识

删除文件需要用到的命令是git rm,且git rm有参数--cached。 当我们需要删除暂存区或分支上的文件,同时工作区也不再需要这个文件了,可以使用:

git rm 文件路径

当我们需要删除暂存区或分支上的文件,但本地又需要使用, 只是不希望这个文件被提交到版本库,可以使用:

git rm --cached 文件路径
文件已添加至暂存区

如果文件被添加到了暂存区,这种情况下直接使用git rm file_path会报错:

$ git rm hello.txt
error: the following file has changes staged in the index:
    hello.txt
(use --cached to keep the file, or -f to force removal)

根据提示我们可以得知,这个时候,如果不想保留hello.txt,则可以使用:

 git rm hello.txt -f

如果想保留hello.txt到工作区则可以使用:

git rm --cached hello.txt
文件已提交至分支

如果文件已经被提交到了某个分支,则可以使用如下命令:

#从当前分支中彻底删除‘文件路径’指定的文件
git rm 文件路径

具体使用方法如:

git rm hello.txt

或者:

#从本地版本库中将‘文件路径’指定的文件删除,并保留到工作区
git rm --cached 文件路径

具体使用方法如下:

git rm --cached hello.txt

但是无论使用哪种方式,都相当于在本地做了修改,在git rm --cached之后,使用git status查看版本库状态,可以得到如下输出:

因此,还需要通过git commit操作将修改提交。

通过以上分析可知,从仓库中删除文件的一般过程为:

git rm <--cached> 文件名
git commit -m "提交信息"
编程要求

平台已为你准备了本地仓库gitTraining,并在master分支进行了一次提交,将文件helloGit提交到了本地仓库。现在需要将helloGit从版本库删除,但还需要将其保留在工作区。 本关的编程任务是,补全右侧代码片段中BeginEnd中间的脚本,将helloGit从本地版本库中删除,但仍保留在工作区。

#进入gitTraining
cd gitTraining

#请在下方Begin至End星号线内填写git命令以丢弃helloGit的修改
#********** Begin **********#


git rm --cached helloGit
#********** End **********#

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/431964.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

人工智能-飞桨

文章目录 概要安装零基础教程基础知识小结 概要 集核心框架、基础模型库、端到端开发套件、丰富的工具组件于一体的深度学习平台 官方入口 安装 python安装 python官方下载 PaddlePaddle安装 python -m pip install paddlepaddle2.6.0 -i https://mirror.baidu.com/pypi/s…

电脑电源电压不足会出现什么问题?怎么办?

电脑电源的电压是多少&#xff1f; 电脑电源输出一般有12V、5V、3.3V三种不同的电压。 电脑电源负责给电脑配件供电&#xff0c;如CPU、主板、内存条、硬盘、显卡等&#xff0c;是电脑的重要组成部分。 新规格的12V、5V、3.3V等输出的电源分配一般更适合当前电脑配件的电源需求…

【中国电信】光猫 PT632 使用超管权限修改 IP 地址租期时间

背景 由于光猫默认设置的动态 IP 租期是 24 小时&#xff0c;所以每天都会断网一次&#xff0c;严重影响用网体验&#xff0c;所以打算通过修改动态 IP 租期为 一周&#xff08;最长就一周&#xff0c;没有永久的选项&#xff09;来改善。 需求 一台电脑&#xff08;已开启 …

网络信息安全:OpenSSH_7.4p1升级至OpenSSH_9.6p1 | ssh-agent远程代码执行漏洞(CVE-2023-38408)

网络&信息安全&#xff1a;OpenSSH_7.4p1升级至OpenSSH_9.6p1 | ssh-agent远程代码执行漏洞(CVE-2023-38408&#xff09; 1.1 风险详情1.2 操作环境1.3 漏洞处理&#xff1a;OpenSSH升级1、查看SSH客户端的版本信息2、列出系统中openssl、openssh的软件包3、启动telnet&…

idea:springboot项目搭建

目录 一、创建项目 1、File → New → Project 2、Spring Initializr → Next 3、填写信息 → Next 4、web → Spring Web → Next 5、填写信息 → Finish 6、处理配置不合理内容 7、注意事项 7.1 有依赖包&#xff0c;却显示找不到依赖&#xff0c;刷新一下maven 二…

SmartX 携手 openGauss 社区发布联合方案评测与性能最佳实践 | 附优化方法与测试数据

近日&#xff0c;北京志凌海纳科技有限公司&#xff08;以下简称 “SmartX”&#xff09;携手 openGauss 社区完成了 openGauss 数据库基于 SmartX 超融合平台&#xff08;SMTX OS&#xff09;和 SmartX 分布式存储平台&#xff08;SMTX ZBS&#xff09;的性能测试和调优。 结…

JVM(垃圾回收机制 ---- GC)

啥是垃圾? 不再使用的内存 啥是垃圾回收机制? 自动释放不用的内存 注意: GC 主要是针对 堆 进行的 GC的基本操作单位是 对象, 即GC’回收的是整个对象都不使用的情况 GC 的优缺点 好处: 省心, 写代码简单, 不易出错 缺点: 需要消耗额外资源, 有额外性能开销 , 此外, 易触发 S…

vue 内容渲染和属性绑定

内容渲染指令 1. 使用v-text指令&#xff0c;将数据采用纯文本方式填充其空元素中 <script setup>import { reactive } from vuelet student reactive({name: Jack,desc: <h3>我是来自中国的小朋友&#xff01;</h3>}) </script> <template><…

介绍下RabbitMQ的事务机制

想要保证发送者一定能把消息发送给RabbitMQ&#xff0c;一种是通过confirm机制&#xff0c;另外一种就是通过事务机制。 RabbitMQ的事务机制&#xff0c;允许生产者将一组操作打包一个原子事务单元&#xff0c;那么全部执行成功&#xff0c;要么全部失败。事务提供了一种确保消…

【开源】JAVA+Vue.js实现食品生产管理系统

目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块2.1 加工厂管理模块2.2 客户管理模块2.3 食品管理模块2.4 生产销售订单管理模块2.5 系统管理模块2.6 其他管理模块 三、系统展示四、核心代码4.1 查询食品4.2 查询加工厂4.3 新增生产订单4.4 新增销售订单4.5 查询客户 五、…

操作系统:初识操作系统

目录 1.冯诺依曼体系结构 2.操作系统 2.1什么是操作系统 2.2为什么需要操作系统 2.3怎么实现操作系统 1.冯诺依曼体系结构 对于上图&#xff1a; 输入设备完成的是写入工作&#xff0c;输出设备完成输出工作&#xff0c;这两部分包含磁盘这类的外存。 存储器一般指的是内存…

【C#杂谈】在 .NET Framework 中使用新的C#语言特性

前排提示&#xff1a;提出一个可以让 [^1] 这中语法可以在.NET Framework运行时中使用的方法 众所都周知&#xff0c;.NET Framework&#xff08;以下简称 .NF&#xff09;作为一个被微软官方确认不在继续发布新特性的运行时&#xff0c;它所对应的C#语言版本被&#xff08;官方…

TruEra

文章目录 关于 TruEra关于 TruLens 关于 TruEra TruEra Gen AI Observability and LLM Evaluation​ Monitor, evaluate, and debug your LLM and Gen AI apps. All part of Full Lifecycle AI Observability from TruEra. 官网&#xff1a;https://truera.comgithub : https…

时间序列分析技巧(一):根据ACF、PACF进行AR、MA、ARMA模型选择

程序员如何选择职业赛道&#xff1f; &#x1f349;CSDN小墨&晓末:https://blog.csdn.net/jd1813346972 个人介绍: 研一&#xff5c;统计学&#xff5c;干货分享          擅长Python、Matlab、R等主流编程软件          累计十余项国家级比赛奖项&#…

定时执行专家 - 自动截屏任务的设置步骤

以下是使用定时执行专家进行自动截屏的设置步骤&#xff1a; 下载并安装定时执行专家 从以下 官方博客 下载最新版本的定时执行专家&#xff0c;并按照提示进行安装。 BoomWorks软件的最新版-CSDN博客文章浏览阅读10w次&#xff0c;点赞9次&#xff0c;收藏42次。▉定时执行…

C语言数据结构与算法——深度、广度优先搜索(DFS、BFS)

目录 一、深度优先搜索&#xff08;Depth-First-Search 简称&#xff1a;DFS&#xff09; 无向图的深度优先搜索 有向图的深度优先搜索 二、广度优先搜索&#xff08;Breadth-First-Search 简称&#xff1a;BFS&#xff09; 无向图的广度优先搜索 有向图的广度优先搜索 深…

市场复盘总结 20240305

仅用于记录当天的市场情况&#xff0c;用于统计交易策略的适用情况&#xff0c;以便程序回测 短线核心&#xff1a;不参与任何级别的调整&#xff0c;采用龙空龙模式 一支股票 10%的时候可以操作&#xff0c; 90%的时间适合空仓等待 二进三&#xff1a; 进级率中 25% 最常用的…

CSS字体样式值,html注释标签

突破困境&#xff1a; 1. 提升学历 前端找工作&#xff0c;学历重要吗&#xff1f; 重要。谁要是告诉你不重要那一定是在骗你。现实情况是大专吃紧&#xff0c;本科够用&#xff0c;硕士占优&#xff0c;大专以下找到工作靠运气和真实力。 学历是硬伤&#xff0c;已经毕业的你…

(黑马出品_02)SpringCloud+RabbitMQ+Docker+Redis+搜索+分布式

&#xff08;黑马出品_02&#xff09;SpringCloudRabbitMQDockerRedis搜索分布式 微服务技术栈治理 今日目标1.Nacos配置管理1.1.统一配置管理1.1.1.在nacos中添加配置文件1.1.2.从微服务拉取配置 1.2.配置热更新1.2.1.方式一1.2.2.方式二 1.3.配…

【Java设计模式】六、代理模式:静态代理、JDK + CGLIB动态代理

文章目录 1、代理对象2、代理模式结构3、静态代理4、JDK动态代理5、JDK动态代理的原理6、CGLIB动态代理7、三种代理的对比8、代理模式的总结 结构型设计是将类或者对象按某种布局&#xff08;继承机制、组合聚合&#xff09;来组成更大结构。包括七种&#xff1a; * 代理模式 …