Git撤销push

继续Git系列,看下push的取消,基本到这里了。

先看文章:

git push了怎么撤销-git-PHP中文网

第一种方法:

看起来是再提交一次,并没有撤销或者说删除上次错误提交的版本。只是不明白,为什么这里要强制推送呢?只记得本地版本比远程版本低时推送要加force参数。比如reset过的版本。

第二种方法:

和下面这篇:

Git撤销已经推送(push)至远端仓库的提交(commit)信息_git撤销已经提交的commit-CSDN博客

以及:

git回退到指定版本,同时提交记录也会删除_git回退过头之前的提交记录消失-CSDN博客

即是讲git reset命令,当然可以实现。相比而言,还是比较简单的,应该用得比较多。注意,其中git reflog是看push的版本号,而不是用git log!后者是看commit的版本号!看下面例子:

但是,看很多文章,好像用git log即commit的版本号也是可以的,都是用git reset命令。想来,上篇也提到过,git reset是可以撤销commit及add的,想必也就撤销了push???

先不管这个了。需要解决一个问题是:加hard参数,有时会报错,即无权限。看:

remote: GitLab:You are not allowed to force push code to a protected branch on this project_remote: gitlab: you are not allowed to force push -CSDN博客

You are not allowed to force push code to a protected branch on this project.-CSDN博客

这都是GitLab的设置,亲测可以修改,然后push --hard就能成功。

另外,下面这个,是不需要用版本号的,但是基本是撤销上个版本的psuh。

[git] 撤销已经push的提交_51CTO博客_git 撤销push上的提交

需要注意的是,无论是用reflog还是log,只要用reset,都是针对commit的,都需要再push一下!且要加force参数。需要特别注意的是:reset其实是删除了其之后的版本!如果之后有别人提交的版本,或者有不需要删除的版本,即,想只撤销某个版本的push,而不是将其后的版本都撤销,那么需要采用revert来做,当然,目标更恰当的说,是变成了删除某指定版本了!

同样其实是先针对commit做操作,再push,所以引文和上篇中一篇一样:

Git进阶命令-revert - 雨点的名字 - 博客园 (cnblogs.com)

还有更高的,用rebase直接修改记录文件(我猜应该是上面一些文中提到的commits文件吧),当然,最后还是要push一下:

git 删除某个中间提交版本 - 刘-皇叔 - 博客园 (cnblogs.com)

暂且就这么多吧。

相关推荐
sduwcgg4 小时前
git经验
git
麻雀无能为力4 小时前
git的使用
git
算法歌者7 小时前
Visual Studio 项目 .gitignore 文件指南
git·visual studio
江边垂钓者7 小时前
git cherry-pick和git stash命令详解
git
Lw老王要学习7 小时前
Linux架构篇、第五章git2.49.0部署与使用
linux·运维·git·云计算·it
爱学习的张哥7 小时前
专栏项目框架介绍
git·fpga开发·udp·ddr·gt收发器
Aric_Jones10 小时前
lua入门语法,包含安装,注释,变量,循环等
java·开发语言·git·elasticsearch·junit·lua
Sapphire~16 小时前
odoo-049 Pycharm 中 git stash 后有pyc 文件,如何删除pyc文件
ide·git·pycharm
Willis_m20 小时前
Linux 服务器用 SSH 拉取多个 Git 工程
linux·服务器·git·ssh
1candobetter20 小时前
git如何将本地 dev 分支与远程 dev 分支同步
git