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)

暂且就这么多吧。

相关推荐
Smile丶凉轩2 小时前
微服务即时通讯系统的实现(服务端)----(1)
c++·git·微服务·github
和你一起去月球11 小时前
TypeScript - 函数(下)
javascript·git·typescript
我不是程序猿儿12 小时前
【GIT】TortoiseGit的变基(Rebase)操作
git
yyycqupt19 小时前
git使用(一)
git
Kkooe1 天前
GitLab|数据迁移
运维·服务器·git
Beekeeper&&P...1 天前
git bash是什么,git是什么,git中的暂存区是什么,git中的本地仓库是什么,git中工作目录指的是什么
开发语言·git·bash
Stara05111 天前
Git推送+拉去+uwsgi+Nginx服务器部署项目
git·python·mysql·nginx·gitee·github·uwsgi
lsswear1 天前
GIT 操作
git
勋勋勋勋小勋勋1 天前
git分支合并某一次提交
git