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,一刀两断,世界瞬间安静。

相关推荐
梦里不知身是客112 小时前
doris的优化器策略介绍
大数据
暗之星瞳3 小时前
mysql表的链接
大数据·数据库·mysql
武子康3 小时前
大数据-191 Elasticsearch 集群规划与调优:节点角色、分片副本、写入与搜索优化清单
大数据·后端·elasticsearch
jason成都3 小时前
jetlinks-扩展TDengine时序库
大数据·时序数据库·tdengine
袋鼠云数栈3 小时前
媒体专访丨袋鼠云 CEO 宁海元:Agent元年之后,产业需回到“数据+智能”的长期结构
大数据·人工智能
涤生大数据4 小时前
放弃Canal后,我们用Flink CDC实现了99.99%的数据一致性
大数据·数据仓库·flink·大数据开发·flink cdc·数据开发·实时数据
云和数据.ChenGuang4 小时前
openEuler安装elasticSearch
大数据·elasticsearch·搜索引擎·全文检索·jenkins
Herlie4 小时前
AI 创业这三年:我的三次认知迭代与自我修正
大数据·人工智能
光仔December4 小时前
【Elasticsearch入门到落地】19、ElasticSearch深度分页问题解决方案:search_after技术详解
elasticsearch·scroll·search_after·from+size·pit