Jor*_*eña 11 git version-control revert
刚才我承诺并推送了一些东西(是的,我在推动时的错误),我认为我应该'还原'或'撤消'.因此我被告知要git reset --soft HEAD^
在我的结尾发布,并且我认为这会以某种方式创建一个"恢复"提交,一旦提交将使它好像改变从未发生过.我不介意改变的历史是否存在,这正是我想象的那样.
无论如何,完成后我再次提交,然后当我试图推动时,我得到了非快进错误.现在,我知道我搞砸了重置,我的树和起源树的线条现在"不匹配",但我想知道如何解决这个问题.现在我只想回到我发出重置之前的时间,这样我就可以通过手动取出它们然后提交来手动恢复更改,除非其他人可以推荐恢复推送提交的正确方法,并且我并不是说历史必须从日志或其他东西中消失.
虽然我的回答超出了您的要求,但我认为这实际上是您打算做的。
您过去常常git reset --soft HEAD^
撤消您所做的提交。这会将工作副本返回到您提交之前的状态(因为HEAD
指向您当前的提交,并HEAD^
指向它之前的一个(假设只有一个父项)。
但是现在,当您git push
被告知以下内容时:
! [rejected] <branch> -> <branch>e (non-fast-forward)
error: failed to push some refs to 'ssh://<remote server>/<remote path>'
hint: Updates were rejected because the tip of your current branch is behind
hint: its remote counterpart. Integrate the remote changes (e.g.
hint: 'git pull ...') before pushing again.
hint: See the 'Note about fast-forwards' in 'git push --help' for details.
Run Code Online (Sandbox Code Playgroud)
这就是说提交没有对齐,它是为了防止你犯错误。错误消息有点误导,你不想按照它的建议去做(拉动你的分支同步)。你只能知道不要因为你的意图而这样做。
你可以简单地用--force
(或-f
)(*)解决这个问题:
git push --force
Run Code Online (Sandbox Code Playgroud)
您可能需要再次设置上游:
git push --force --set-upstream origin <branch>
Run Code Online (Sandbox Code Playgroud)
请注意,如果其他人已经撤回了您的工作,这将产生后果,因为会有不同的提交进行相同的更改(可能)。请参阅https://www.kernel.org/pub/software/scm/git/docs/user-manual.html#problems-With-rewriting-history。
为防止出现任何问题,只推送到您的分支(而不是某些公共分支 - 例如development
开发人员将其所有功能分支合并到的分支),并确保在您的团队中进行开放式沟通。
开发人员通常会将这种模式用于我所说的星期五下午提交,您希望在周末之前保存您的工作以防硬件故障(但在星期一返回预提交状态)。
*Friday*
git add --all # To add all files whether they are tracked or not
git commit -m "Friday afternoon commit"
git --set-upstream push # --set-upstream is for if the branch doesn't exist on the remote server
*Monday*
git reset --soft HEAD^
git push -f --set-upstream origin <branch>
Run Code Online (Sandbox Code Playgroud)
与git revert
另一个答案中讨论的相比,这样做的好处是避免额外的提交。重置将有 2 次提交,这种方式将没有(没有额外的)。的优点git reset
是它不会重写历史,因此更安全,尤其是当您不确定自己在做什么时。
(*) 通常,存储库配置为不允许您执行此操作来掌握 - 在分支上修复并创建拉取请求。因为如果您已经阅读了上面的链接,那么在 master 上重写历史将产生严重的后果(除非您是唯一克隆该代码的人)。
如果我正确理解您的问题,您可以尝试以下方法:
(我假设这是你的'主'分支,你正在推动'起源')
与遥控器同步以进入相同的状态.
git remote update
git checkout master
git merge origin/master
Run Code Online (Sandbox Code Playgroud)
现在还原你的提交
git revert HEAD (or where ever the commit you want to revert is now)
git commit -av
Run Code Online (Sandbox Code Playgroud)
与遥控器同步
git push
Run Code Online (Sandbox Code Playgroud)
现在我只想回到发出重置之前的时间
如果您只想取消git reset --soft
刚刚取消的操作,可以在reflogs中查找以前的HEAD提交ID
$ git reflog
$ git reset --soft formerCommit
Run Code Online (Sandbox Code Playgroud)
然后你可以准备你的 git revert