假设我们在Git中有以下情况:

创建的存储库: mkdir GitTest2 cd GitTest2 git init 在master中发生并提交一些修改: echo“On Master”>文件 初始提交 Feature1分支了master并完成了一些工作: Git分支feature1 Git签出特性1 echo "Feature1" > featureFile git commit -a -m commit for feature1 同时,在主代码中发现了一个bug,并建立了一个热修复分支: Git checkout master Git分支hotfix1 Git签出hotfix1 该错误在热修复分支中修复,并合并回主程序(可能在拉取请求/代码审查之后): echo "Bugfix" > bugfixFile git commit -a -m " bug修正提交" Git checkout master Git merge -no-ff hotfix1 feature1的开发仍在继续: Git签出特性1

假设我需要在我的功能分支中进行热修复,可能因为bug也发生在那里。我怎样才能在不复制提交到我的特性分支的情况下实现这一点呢?

我想防止在我的特性分支上获得两个与特性实现无关的新提交。如果我使用拉请求,这对我来说尤其重要:所有这些提交也将包含在拉请求中,并且必须进行审查,尽管这已经完成了(因为热修复已经在master中)。

我不能做一个git合并主-ff-only: "fatal: not possible to fast-forward, aborting.",但我不确定这是否帮助了我。


当前回答

In Eclipse -

1)结账主分支

Git Repositories ->Click on your repository -> click on Local ->double click master branch
->Click on yes for check out

2)拉主分支

Right click on project ->click on Team -> Click on Pull

3)检查你的功能分支(遵循第一点提到的相同步骤)

4)将master合并为feature

Git Repositories ->Click on your repository -> click on Local ->Right Click on your selected feature branch ->Click on merge ->Click on Local ->Click on Master ->Click on Merge.

5)现在你会在feature branch中看到Master branch的所有变化。消除冲突。

For conflict if any exists ,follow this -
Changes mentioned as Head(<<<<<< HEAD) is your change, Changes mentioned in branch(>>>>>>> branch) is other person change, you can update file accordingly.

注意-您需要为冲突文件添加索引

6)提交并在功能分支中推送你的更改。

Right click on project ->click on Team -> Click on commit -> Commit and Push.

OR

Git Repositories ->Click on your repository -> click on Local ->Right Click on your selected feature branch ->Click on Push Branch ->Preview ->Push

其他回答

根据这篇文章,你应该:

创建基于master新版本的新分支 Git分支-b newmaster 将旧的功能分支合并为新的 Git checkout newmaster 解决新特性分支上的冲突

前两个命令可以组合成git checkout -b newmaster。

这样,您的历史记录将保持清晰,因为您不需要反向合并。你不需要这么小心谨慎,因为你不需要做Git的基础。

我们如何将主分支合并到特征分支中?容易:

git checkout feature1
git merge master

在这里强制快速前进合并是没有意义的,因为这是不可能做到的。你同时提交了特性分支和主分支。现在快进是不可能的。

看看GitFlow。这是一个可以遵循的git分支模型,您已经在不知不觉中遵循了。它也是Git的一个扩展,它为新的工作流步骤添加了一些命令,这些命令可以自动执行,否则您需要手动执行。

那么你在工作流程中做对了什么?你有两个分支可以使用,你的feature1分支基本上是GitFlow模型中的“develop”分支。

您从master创建了一个热修复分支,并将其合并回来。现在你被困住了。

GitFlow模型要求您将热修复程序合并到开发分支,在您的示例中是“feature1”。

所以真正的答案是:

git checkout feature1
git merge --no-ff hotfix1

这将把在热修复程序中所做的所有更改添加到功能分支中,但仅限于这些更改。它们可能会与分支中的其他开发变更发生冲突,但是如果您最终将特性分支合并回主分支,则它们不会与主分支发生冲突。

换基时要非常小心。只有当你所做的更改停留在你的存储库的本地时,才会进行基改,例如,你没有将任何分支推到其他存储库。重基是一个很好的工具,可以让你在提交之前把本地提交安排成一个有用的顺序,但是对像你这样的git初学者来说,重基会把事情搞砸。

我在特征分支上进行重构。我现在想合并主更改到我的功能分支。我远远落后了。注意,我不想把主更改拉到本地,因为我的特性分支有模块从一个地方移动到另一个地方。我发现仅仅在没有拉力的情况下表演是行不通的。上面写着“已更新”。

 //below does not get the latest from remote master to my local feature branch without git pull
    git checkout master 
    git fetch 
    git checkout my-feature-branch 
    git merge master

下面的工作,注意使用git合并origin/master:

 git checkout master 
    git fetch 
    git checkout my-feature-branch 
    git merge origin/master

补充现有的答案,因为这些命令是循环的,我们可以在一行中完成它。假设我们在特征分支:

git checkout master && git pull && git checkout - && git merge -

或者将它们添加到别名中:

alias merge_with_master="git checkout master && git pull && git checkout - && git merge -"

git 合并

您可以按照以下步骤进行操作

1. 合并源/主分支到特征分支

# step1: change branch to master, and pull to update all commits
$ git checkout master
$ git pull

# step2: change branch to target, and pull to update commits
$ git checkout feature
$ git pull

# step3: merge master to feature(⚠️ current is feature branch)
$ git merge master


2. 将特征分支合并到原点/主分支

Origin /master是远程主分支,而master是本地主分支

$ git checkout master
$ git pull origin/master

$ git merge feature
$ git push origin/master