Git常用命令:
git add .               #进行提交
git commit -m v2            #v2版本
cat index.html              #查看文件内容已经变化
git log                  #获取到提交信息
git reset --hard 50127d43d2dc      #执行回滚,后面需要跟commit ID
cat index.html             #再次查看文件内容发现已经回滚到v1版本
git log                 #发现无法获取到v2版本commt id
git reflog               #获取到所有的历史提交信息
git reset --hard 7ff3f54        #回滚到版本2

git不同阶段回滚
  1.工作目录
  2.暂存区域
  3.仓库版本回滚

演示:撤销工作区的内容

第一步:创建一个文件

[root@docker2 git_test]# cat .txt 

[root@docker2 git_test]# echo 'test1' >> .txt
[root@docker2 git_test]# echo 'test2' >> .txt

第二步:把这个文件添加到缓存区

[root@docker2 git_test]# git add .

第三步:在文件追加内容

在包含.git的目录中,只要当前目录下的文件有修改都会自动进入工作区(该文件必须被commit过,否则无法追踪)

所以下面当往文件e.tt中添加test3的时候。e.tt这个文件就进入到了工作区了。

  1.文件进入工作区 :包含.git隐藏文件的目录中,文件修改就会自动进入

  2.文件进入缓存区 :git add .

  3.文件进入仓库  :git commit -m ‘v1’

[root@docker2 git_test]# echo "test3" >> .txt 

第四步:查看工作区

[root@docker2 git_test]# git status

# 位于分支 master
# 要提交的变更:
# (使用 "git reset HEAD <file>..." 撤出暂存区)
#
# 修改: 1.txt
#
# 尚未暂存以备提交的变更:
# (使用 "git add <file>..." 更新要提交的内容)
# (使用 "git checkout -- <file>..." 丢弃工作区的改动)
#
# 修改: 1.txt
#

第五步:撤销工作区的内容

使用命令git checkout — filename即可进行回滚
[root@docker2 git_test]# git checkout -- .txt #数据回滚
[root@docker2 git_test]# git status #查看状态
# 位于分支 master
# 要提交的变更:
# (使用 "git reset HEAD <file>..." 撤出暂存区)
#
# 修改: .txt
#
[root@docker2 git_test]# cat .txt #查看文件内容,发现test3内容已经没有了 test1
test2

演示:撤销缓存区的内容

第一步:创建文件并进行提交

[root@ken kenken]# echo "">k.tt
[root@ken kenken]# git add k.tt
[root@ken kenken]# git commit -m "k.tt"
[root@ken kenken]# git log
commit c5f46907ce0dfd6722b091fa7a7053ff48507ace
Author: ken <@qq.com>
Date: Tue Nov :: + k.tt

第二步:修改文件并加入到缓存区中
第一步一定要提交,才能看到效果

[root@docker2 git_test]# echo  >> .txt
[root@docker2 git_test]# echo >> .txt
[root@docker2 git_test]# git add .
[root@docker2 git_test]# git status

# 位于分支 master
# 要提交的变更:
# (使用 "git reset HEAD <file>..." 撤出暂存区)
#
# 修改: 1.txt

第三步:缓存区进行回退

[root@docker2 git_test]# git reset HEAD .txt 

重置后撤出暂存区的变更:
M 1.txt

第四步:缓存区进行回退

[root@docker2 git_test]# git status

# 位于分支 master
# 尚未暂存以备提交的变更:
# (使用 "git add <file>..." 更新要提交的内容)
# (使用 "git checkout -- <file>..." 丢弃工作区的改动)
#
# 修改: 1.txt
#
修改尚未加入提交(使用 "git add" 和/或 "git commit -a")

第五步:工作区进行回滚
其实现在就已经回到了演示2中了
回退完成之后可以发现之前写的666和777 已经没有了

[root@docker2 git_test]# git checkout -- .txt
[root@docker2 git_test]# git status
# 位于分支 master
无文件要提交,干净的工作区
[root@docker2 git_test]# cat .txt

演示:撤销仓库中的内容

第一步:查看历史版本
我们现在处于1.txt中,现在希望回到v3中

[root@docker2 git_test]# git log
commit a7dbf086621335d775596ba834150d0407bcb736
Author: wuxun <@qq.com>
Date: Mon Nov :: + v4 commit baeec2884d5d9fec0e17eac4069dcc6ce1e39595
Author: wuxun <@qq.com>
Date: Mon Nov :: + v3 commit 14820ed1cce6df5e5a5d5129f8fd0c5f54bf5b8a
Author: wuxun <@qq.com>
Date: Mon Nov :: + v2 commit 72b6d22dfbba2b0f01c74bf0ea105875b8b2edf8
Author: wuxun <@qq.com>
Date: Mon Nov :: + v1

第二步:查看所需要回滚的版本的commit值
通过上面我们可以看到v3的commit值commit baeec2884d5d9fec0e17eac4069dcc6ce1e39595

第三步:执行回滚操作
commit值没有必要全部写出来,只要写一部分就可以了

[root@docker2 git_test]# git reset --hard baeec2884d
HEAD 现在位于 baeec28 v3

第四步:查看版本状态
现在我们处于v3版本之中

[root@docker2 git_test]# git log
commit baeec2884d5d9fec0e17eac4069dcc6ce1e39595
Author: wuxun <@qq.com>
Date: Mon Nov :: + v3 commit 14820ed1cce6df5e5a5d5129f8fd0c5f54bf5b8a
Author: wuxun <@qq.com>
Date: Mon Nov :: + v2 commit 72b6d22dfbba2b0f01c74bf0ea105875b8b2edf8
Author: wuxun <@qq.com>
Date: Mon Nov :: + v1

第五步:回退到v4版本中
我们知道回退版本需要用到commit值
但是现在通过git log已经看不到v4的commit值了,现在怎么办呐?
可以通过git reflog查看所有的历史操作
找到v4前面的值即可

[root@docker2 git_test]# git reflog
baeec28 HEAD@{}: reset: moving to baeec2884d
a7dbf08 HEAD@{}: commit: v4
baeec28 HEAD@{}: commit: v3
14820ed HEAD@{}: reset: moving to 14820ed
72b6d22 HEAD@{}: reset: moving to 72b6d22dfbba2b0f01c74bf0ea105875b8b2edf8
14820ed HEAD@{}: commit: v2
72b6d22 HEAD@{}: commit (initial): v1

第六步:回滚到v4版本

root@docker2 git_test]# git reset --hard a7dbf08
HEAD 现在位于 a7dbf08 v4
[root@docker2 git_test]# git log
commit a7dbf086621335d775596ba834150d0407bcb736
Author: wuxun <@qq.com>
Date: Mon Nov :: + v4 commit baeec2884d5d9fec0e17eac4069dcc6ce1e39595
Author: wuxun <@qq.com>
Date: Mon Nov :: + v3 commit 14820ed1cce6df5e5a5d5129f8fd0c5f54bf5b8a
Author: wuxun <@qq.com>
Date: Mon Nov :: + v2 commit 72b6d22dfbba2b0f01c74bf0ea105875b8b2edf8
Author: wuxun <@qq.com>
Date: Mon Nov :: + v1

Git的回滚的更多相关文章

  1. Git如何回滚代码?

    摘要: 多年以后,你面对一个需要回滚的Git仓库,准会想起这篇博客. 某一天,用户跟我反馈,他不能分配任务了.我去看了一下Fundebug捕获的报错信息: 可知,出错原因是前端发送的请求参数有问题.这 ...

  2. git代码回滚的两种选择

    回滚到指定commit,且保持该commit之前和之后的提交记录 使用git revert命令. git revert HEAD // 回滚到前一次 commit git revert HEAD^ / ...

  3. git如何回滚当前修改的内容?

    git如何回滚当前修改的内容? 1.打开git gui,在工具栏上点击 commit ,选择 Revert Changes,  这里可以回滚单个文件: 2.一键回滚所有修改: 打开git gui,在工 ...

  4. git代码回滚:Reset、Checkout、Revert的选择

    代码回滚:Reset.Checkout.Revert的选择 Zhongyi Tong edited this page on Dec 8, 2015 · 5 revisions Pages 19 Ho ...

  5. git版本号回滚

    先说今天遇到的问题,看到一个config.php的配置文件一直在改动的状态下,可是和远程的config.php是不一致的,我不须要提交它,可是看它在 modified的状态下,非常不爽.想删除它.gi ...

  6. git 版本回滚

    1.克隆代码到本地 git clone http://qtools@dev.qtoolsbaby.cn:81/gitlab/qtools/jenkins_ceshi.git 2.git log 查看所 ...

  7. Git撤销&回滚操作

    https://blog.csdn.net/ligang2585116/article/details/71094887 开发过程中,你肯定会遇到这样的场景: 场景一: 糟了,我刚把不想要的代码,co ...

  8. 6.Git代码回滚

    1.代码修改并提交 我们已经成功地添加并提交了一个helloWorld.txt文件,现在,是时候继续工作了. 于是,我们继续修改helloWorld.txt文件,改成如下内容: $ vi helloW ...

  9. git 分回滚后无法合并代码问题

    git reset & git revert 区别: 1. git revert是用一次新的commit来回滚之前的commit,git reset是直接删除指定的commit. 2. 在回滚 ...

随机推荐

  1. Windows 防火墙无法更改某些设置错误代码 0x80070422

    Windows 防火墙无法更改某些设置错误代码 0x80070422 解决方法: 1.cmd ->services.msc 按下回车键打开服务 :   2.在服务界面双击打开[Windows F ...

  2. nexus搭建maven仓库管理

    Linux搭建nexus仓库 1.安装jdk 1.1 获取安装包,解压到指定目录: 1 tar xf jdk.tar.gz -C /opt/export 1.2 配置环境变量: 1 # vim /et ...

  3. paramiko 远程执行多个命令

    转发博客如下 https://blog.csdn.net/c_base_jin/article/details/86561445

  4. 【shell脚本】定时备份日志===logBackup.sh

    定时备份日志 设置执行权限 [root@VM_0_10_centos shellScript]# chmod a+x logBackup,sh 脚本内容 [root@VM_0_10_centos sh ...

  5. background-size:100% 100% 和 background-size:cover的区别简述

    下面我通过给下图背景图添加background-size属性的不同属性值,更直观的显示出100%和cover的区别   下图是添加background-size:100% 100% 后的背景图效果,背 ...

  6. RESTful Webservice 和 SOAP Webserivce 对比及区别【转】

    接口抽象 RESTful Web 服务使用标准的 HTTP 方法 (GET/PUT/POST/DELETE) 来抽象所有 Web 系统的服务能力,而不同的是,SOAP 应用都通过定义自己个性化的接口方 ...

  7. .net core linux环境下 System.Data.SqlClient.SqlException: Connection Timeout Expired.

    最近遇到了一个很奇葩的问题,我编写了一个.net core程序读取多个数据库数据源,进行数据同步处理.该程序在windows环境下运行完全正常,但在linux环境下运行报异常,提示 System.Da ...

  8. 从零开始实现放置游戏(六)——实现后台管理系统(4)Excel批量导入

    前面我们已经实现了在后台管理系统中,对配置数据的增删查改.但每次添加只能添加一条数据,实际生产中,大量数据通过手工一条一条添加不太现实.本章我们就实现通过Excel导入配置数据的功能.这里我们还是以地 ...

  9. 接口interface实现与显示实现

    接口实现: interface IMath { void Add(int x, int y); } public class MathClass : IMath { public void Add(i ...

  10. 重温CLR(十八) 运行时序列化

    序列化是将对象或对象图转换成字节流的过程,反序列化是将字节流转换回对象图的过程.在对象和字节流之间转换是很有用的机制. 1 应用程序的状态(对象图)可轻松保存到磁盘文件或数据库中,并在应用程序下次运行 ...