我有四个分支(master, b1, b2和b3)。我在b1-b3上工作后,我意识到我在分支主上有一些应该在所有其他分支中更改的东西。我改变了我在master中需要的东西…这是我的问题:
我如何用主分支代码更新所有其他分支?
我有四个分支(master, b1, b2和b3)。我在b1-b3上工作后,我意识到我在分支主上有一些应该在所有其他分支中更改的东西。我改变了我在master中需要的东西…这是我的问题:
我如何用主分支代码更新所有其他分支?
当前回答
用你的主分支副本更新其他分支,如(备份)。 你可以按照任何一种方式(rebase或merge)…
做rebase(不会有任何额外的提交到备份分支)。 合并分支(将有一个额外的自动提交到 备份分支)。 注:Rebase只是建立一个新的base(一个新的副本)
git 结帐备份 Git 合并大师 git push
(重复执行其他分支,如backup2等)
git 结帐备份 git 变基大师 git push
(重复执行其他分支,如backup2等)
其他回答
有两种方法
您希望将主分支合并到您的分支中 - git checkout master - git拉 - git checkout your-feature-branch - git merge master //解决冲突并提交 - git push
2:如果你想在main的基础上重新调整你的改变。
git checkout master #Switch to main branch
git pull #Take latest
git checkout your-feature-branch #Switch to story branch
git pull --ff-only # Ensure branch is up to date
git rebase -i origin master #Interactively rebase your commits on top of master. So your changes are on top of latest commits in main.
git rebase --continue #Resolve conflicts and rebase --continue to continue with next commits
git push -f origin your-feature-branch # As you have rewritten the commit history, you have to **force push** the commits
Git rebase master是正确的方法。合并意味着将为合并创建一个提交,而重基则不会。
如果你想要恢复到上一次提交并删除日志历史记录
使用下面的命令,让我们假设你想要去到以前的提交,它有commititid SHA - 71e2e57458bde883a37b332035f784c6653ec509,你可以指向这个提交,它将不会显示任何日志消息在这个提交之后,所有的历史将被擦除。
git push origin +71e2e57458bde883a37b332035f784c6653ec509^:master
您可以合并,也可以使用git的选择性跨分支应用单独的提交。
令人惊讶的是,我最常用的方法没有被提及。这在基于Trunk的开发风格中是很常见的,其中main不断更新,并且从它的分支中工作。
假设main已经有了更新的代码,并且你在分支b1中。如果不是这种情况,您将需要git fetch。
因此,要用main中所做的更改更新b1,只需使用
git pull origin main
当您或其他人到达其他分支并想要更新时,也必须在其他分支中进行相同的操作。