git本地提交后,解决push被拒绝 error: failed to push some refs to

前言

下午改完需求

bash 复制代码
git add .
git commit -m "feat: 新增推荐接口"
git push origin dev

结果终端突然翻脸:

复制代码
! [rejected]        dev -> dev (fetch first)
error: failed to push some refs to 'github.com:xxx/xxx.git'
hint: Updates were rejected because the remote contains work that you do not have locally.

Git 贴心地提示:先 git pull 把远程新提交合并进来。

我照做,却又被泼一盆冷水:

复制代码
hint: You have divergent branches and need to specify how to reconcile them.
fatal: Need to specify how to reconcile divergent branches.

一句话总结:本地与远程分叉了,Git 不知道听谁的,干脆罢工。


原因

  1. 远程仓库在我本地开发期间又多了新提交(同事 merged PR)。
  2. 我本地也产生了新的 commit,但还没 push。
  3. 两者从同一个祖先分叉(diverged),Git 默认拒绝"覆盖"远程历史。

需求

我不想保留本地这次 commit,只想让本地代码完全回到远程最新状态 ,相当于"我什么都没改"。

于是目标变成:撤回本地 commit,并丢弃对应改动


操作步骤(放弃本地 commit 版)

  1. 先把远程最新状态拉下来(只更新远程跟踪分支,不影响本地)

    bash 复制代码
    git fetch origin
  2. 强制让当前分支指针回到远程版本,同时清空工作区

    bash 复制代码
    git reset --hard origin/dev
    • --hard 会连同工作区一起回退,本地改动全部丢失,请确保不需要它们。
    • 如果只想保留改动,用 --soft--mixed,详见文末彩蛋。
  3. (可选)再次推送

    bash 复制代码
    git push origin dev

    此时由于本地与远程一致,push 直接成功。


疑问

疑问 解答
撤回后能找回原来的 commit 吗? 只要没有 git gc,可用 git reflog 找回哈希值,再 git cherry-pickgit branch 切回来。
已经 push 了还能这样撤回吗? 可以,但需要 git reset 后加 git push --force-with-lease会改写远程历史,团队慎用!
下次不想手动选策略? 设置默认 pull 行为:git config pull.rebase truegit config pull.ff only

三分钟速记表

目标 命令
撤回最近 1 次 commit,代码保留在暂存区 git reset --soft HEAD~1
撤回最近 1 次 commit,代码退回工作区 git reset --mixed HEAD~1
撤回最近 1 次 commit,连代码一起丢 git reset --hard HEAD~1
本地直接同步远程分支(放弃所有本地提交) git fetch origin && git reset --hard origin/分支名

总结

Git 不会替你决定"谁对谁错",它只会把选择权交给你。

下次遇到"fetch first"别慌,先想清楚:是要合并,还是要放弃

一旦确认放弃,就 fetch + reset --hard,一刀两断,世界瞬间安静。

相关推荐
L***一3 小时前
大数据技术专业中专生职业发展路径探析
大数据
woshikejiaih3 小时前
**播客听书与有声书区别解析2026指南,适配不同场景的音频
大数据·人工智能·python·音视频
无忧智库4 小时前
某市“十五五“智慧气象防灾减灾精准预报系统建设方案深度解读 | 从“看天吃饭“到“知天而作“的数字化转型之路(WORD)
大数据·人工智能
AllData公司负责人4 小时前
AllData数据中台-数据同步平台【Seatunnel-Web】整库同步MySQL同步Doris能力演示
大数据·数据库·mysql·开源
acrelwwj4 小时前
智慧照明新引擎,ASL600 4GWJ开启城市照明精细化管理新时代
大数据·经验分享·物联网
2501_943695334 小时前
高职大数据技术专业,怎么参与开源数据分析项目积累经验?
大数据·数据分析·开源
承渊政道5 小时前
Linux系统学习【Linux系统的进度条实现、版本控制器git和调试器gdb介绍】
linux·开发语言·笔记·git·学习·gitee
Doro再努力5 小时前
【Linux操作系统12】Git版本控制与GDB调试:从入门到实践
linux·运维·服务器·git·vim
Dxy12393102165 小时前
别再让 ES 把你拖垮!5 个实战技巧让搜索性能提升 10 倍
大数据·elasticsearch·搜索引擎
2501_943695336 小时前
大专市场调查与统计分析专业,怎么辨别企业招聘的“画饼”岗位?
大数据