Git回滚远程版本

简介:

“房子是租的 但生活不是”

1.故事的开始

远程master分支下代码被不小心提交了很多垃圾代码或项目删掉,想要回滚到以前的某一版本并删除commit log。怎么办?情景如图:

1

情景很简单。老板上传了个文件,我把他删掉了。有一种办法,把文件再push下,但是也不想他看到图中那comment(ps:这样我才不会被fire)。实现上面场景的代码如下:

  1. vim A.txt
  2. git add .
  3. git commit --"add A.txt"
  4. git push
  5. rm A.txt
  6. git commit --"我删除了老板的东西"
  7. git push

————–分割线 ————–

一头雾水的小白怎么办?怎么办?怎么办?

push到远程的提交默认是不能修改的,但是一定要修改不是不行:

  1. git push -f

 

2.解决之道

2.1工作区,暂存区,本地版本库 & 远程版本库

No pic say 个 78。。。

2

》》工作区:就是我们操作的目录

》》暂存区:操作目录的快照

》》本地版本库:Git的精髓,人人都是中央仓库。也就是Git分布式的好处,自然对比SVN这种集中式

》》远程版本库:Github这种中央仓库,可以达到共享。

常用的操作也如图所示,不言而喻了。

 

2.2 实战解决

Talk is cheap,Show me the code or money~ 代码如下:

  1. git log
  2. git reset --soft ${commit-id}
  3. git stash
  4. git push -f

详解如下:

 

第1行:git log 查看提交历史,然后找到要回滚的版本。历史如下,

  1. commit 84686b426c3a8a3d569ae56b6788278c10b27e5b
  2. AuthorJeffLi1993 <qiangqiangli1993@gmail.com>
  3. Date:   Fri Apr 19:11:32 2016 +0800
  4.    我删除了老板的东西
  5. commit 72bd6304c3c6e1cb7034114db1dd1b8376a6283a
  6. AuthorJeffLi1993 <qiangqiangli1993@gmail.com>
  7. Date:   Fri Apr 19:05:23 2016 +0800
  8.    add A.txt

我们想要回滚到的版本就是:72bd6304c3c6e1cb7034114db1dd1b8376a6283a

 

第2行:git reset –soft 72bd6304c3c6e1cb7034114db1dd1b8376a6283a

撤销到某个版本之前,之前的修改退回到暂存区(不懂看漂亮的图哦~)。soft 和 hard参数的区别就是,hard修改记录都没了,soft则会保留修改记录。

 

第3行:暂存为了安全起见。

 

第4行:git push -f

将本地master push 到远程版本库中, -f 强制覆盖

 

3. 小结

git reset 回滚到某个版本之前
git push -f 强制push覆盖

相关文章
|
开发工具 git C++
『实用教程』使用Visual Studio自带的Git管理回滚代码版本
使用Visual Studio自带的Git管理回滚代码版本
1209 0
『实用教程』使用Visual Studio自带的Git管理回滚代码版本
|
29天前
|
开发工具 git
IDEA通过git回滚到某个提交节点或某个版本的操作方法
IDEA通过git回滚到某个提交节点或某个版本的操作方法
15 0
|
8月前
|
存储 缓存 运维
【运维知识高级篇】一篇文章带你搞懂Git!(Git安装+全局配置+Git初始化代码仓库+Git四大区域+Git四种状态+Git常用命令+Git分支+Git测试代码回滚)
【运维知识高级篇】一篇文章带你搞懂Git!(Git安装+全局配置+Git初始化代码仓库+Git四大区域+Git四种状态+Git常用命令+Git分支+Git测试代码回滚)
169 0
|
4月前
|
存储 开发工具 git
(详解踩坑)GIT版本回滚git stash、git reset、git reset --hard、git revert
(详解踩坑)GIT版本回滚git stash、git reset、git reset --hard、git revert
60 0
|
5月前
|
开发工具 git
idea回滚git仓库代码
idea回滚git仓库代码
60 0
|
10月前
|
开发工具 git
git命令回滚撤销自己的错误覆盖提交
git命令回滚撤销自己的错误覆盖提交
96 0
|
11月前
|
缓存 Shell 开发工具
研发中学习git(删除分支/合并提交/回滚/保存当前状态/撤销修改)
研发中学习git(删除分支/合并提交/回滚/保存当前状态/撤销修改)
116 0
|
开发工具 git
git 主干master分支回滚到历史版本
1.回滚到指定版本 2.强制推送到远程分支
235 0
|
开发工具 git
|
开发工具 git
Git本地回滚重新修改代码再push到远程问题
Git本地回滚重新修改代码再push到远程问题
440 0