如何解决fork仓库的开发分支push到了fork仓库的master分支上?

问题背景

我fork了仓库,新建了fix_patch_xxx分支来解决问题 然后pull request提交到apache/eventmesh(一般fork的仓库的master分支是不直接开发的 用来保持和源仓库的代码一致)

此时 马大哈本地commit完了之后没有设置这个分支的upstream,导致使用git GUI的时候直接推送到了master分支上。(1 commit behind是因为其他分支已经将pr合到主仓库中了)

尝试解决

  1. git revert git revert用于远程回退 git reset用于本地回退

两者的一个重要区别是前者会留一次commit,后者不会留:

凸(艹皿艹 ) 变成两个commit了,并且可以看到commit信息是revert上次commit

  1. 用git自带的discard

点了半天没啥反应 或者是有冲突?

  1. 尝试解决第二种方案的冲突问题

悲 把上面的revert的又merge回来了

(纯属本人不熟悉操作,如有会的小伙伴希望能评论区指点 感谢)

高人指点

简而言之:将你自己fork的仓库作为远程,原来的主仓库作为源,强制push。

(出错的原因是仓库master分支有protect rule,在仓库的settings中可以关闭)

这样就可以解决了!

后续思考

既然有这样的upstream和origin了,为啥不直接强制用upstream更新origin!?

在Git中,你可以使用以下命令强制将 upstream 分支的代码更新到 origin 分支:

sql 复制代码
git fetch upstream
git checkout your_branch_name
git merge -Xtheirs upstream/remote_branch_name
git push origin your_branch_name

上述命令的步骤是:

  1. git fetch upstream:从 upstream 远程仓库获取最新的代码。
  2. git checkout your_branch_name:切换到你的本地分支。
  3. git merge -Xtheirs upstream/remote_branch_name:合并 upstream 分支到你的本地分支。这里使用了 -Xtheirs 选项,表示在合并冲突时优先选择 upstream 分支的更改。
  4. git push origin your_branch_name:将更新后的本地分支推送到 origin 远程仓库。
相关推荐
明月与玄武13 分钟前
Jenkins+Docker+Git实现自动化CI/CD
git·docker·jenkins·ci/cd流水线
霍格沃兹测试开发28 分钟前
Playwright系列课(2) | 元素定位四大法宝:CSS/文本/XPath/语义化定位实战指南
开源·测试
QZQ5418840 分钟前
xv6实现写时复制机制
开源
小诸葛的博客1 小时前
istio如何自定义重试状态码
云原生·github·istio
MrLi01041 小时前
在git中同时配置gitcode和github访问权限
git·github·gitcode
越来越无动于衷1 小时前
Git 团队协作完全指南:从基础到高级应用
git
小怪兽会微笑1 小时前
如何上传github(解决git的时候输入正确的账号密码,但提示认证失败)
git·github
说私域2 小时前
基于开源AI大模型、AI智能名片与S2B2C商城小程序源码的用户价值引导与核心用户沉淀策略研究
人工智能·开源
说私域2 小时前
线上协同办公时代:以开源AI大模型等工具培养网感,拥抱职业变革
人工智能·开源
Dontla2 小时前
Fair-code介绍(Fair code)(一套新型软件模型:旨在“开源”&“商业可持续性”中找到平衡)
开源