在git重新启动/开发过程中,git显示以下错误消息:
fatal: refusing to merge unrelated histories
Error redoing merge 1234deadbeef1234deadbeef
我的Git版本是2.9.0。它在以前的版本中运行良好。
我如何才能继续使用新版本中引入的强制标志来允许不相关的历史?
在git重新启动/开发过程中,git显示以下错误消息:
fatal: refusing to merge unrelated histories
Error redoing merge 1234deadbeef1234deadbeef
我的Git版本是2.9.0。它在以前的版本中运行良好。
我如何才能继续使用新版本中引入的强制标志来允许不相关的历史?
当前回答
我使用rebase多年了,从未遇到过这样的问题。然而,您的第一个问题是,您试图从远程存储库(称为origin)直接在远程分支开发上执行此操作。这实际上是错误的,因为rebase是一个危险的命令,它会重新构建git历史。话虽如此,但您应该首先尝试本地存储库,并仅在符合预期的情况下推送它。
因此,我通常的rebase工作流如下所示(但请记住,您不应在分支机构上使用rebase,因为您不是唯一的一个委员会。对于此类分支机构,如果适用,请使用简单的合并和解决冲突):
确保您有一个干净的工作树(没有取消提交的更改)签出到您要重新基于的分支(例如,假设它是master;作为单行命令):gitcheckout-master&&gitpull-origin-master&&gitcheckout-development执行实际的rebase:git rebase-master如果已经完成,并且一切都按预期运行,请将其推到远程。为此,您需要强制它,因为远程主机已经按另一顺序拥有历史记录,所以远程主机将无需推送任何内容。所以,我们需要说“我的本地版本的历史是正确的,使用我的本地历史版本覆盖远程分支上的所有内容”:git push-f origin开发
正如我已经提到的,记住,rebase操纵git历史,这通常是一件坏事。然而,在分支上也可以做到这一点,因为其他人都不承诺这样做。为了让其他开发人员能够使用分支,可以使用另一种合并策略,如合并本身、squash或cherrypick。因此,换句话说:Rebase不应该成为分布式开发的工具。如果您是唯一在这个存储库上工作的人,那么它很适合您。
我们使用特征分支策略。在这种情况下,我通常使用rebase从其他开发人员那里获得“更新”,这是在主分支上同时发生的。这样做可以减少拉取请求中可见的提交大小。因此,代码审阅者更容易看到我在这个特性分支中所做的更改。
其他回答
尝试git pull--重新基础开发
在我的案例中,错误是致命的:每次尝试都拒绝合并不相关的历史记录,尤其是远程添加Git存储库后的第一次拉取请求。
使用--allow不相关的历史标记以这种方式处理拉取请求:
git pull origin branchname --allow-unrelated-histories
根据2.9.0发行说明,git pull已被教导将--allow unrelated history选项传递给基础git merge
我使用rebase多年了,从未遇到过这样的问题。然而,您的第一个问题是,您试图从远程存储库(称为origin)直接在远程分支开发上执行此操作。这实际上是错误的,因为rebase是一个危险的命令,它会重新构建git历史。话虽如此,但您应该首先尝试本地存储库,并仅在符合预期的情况下推送它。
因此,我通常的rebase工作流如下所示(但请记住,您不应在分支机构上使用rebase,因为您不是唯一的一个委员会。对于此类分支机构,如果适用,请使用简单的合并和解决冲突):
确保您有一个干净的工作树(没有取消提交的更改)签出到您要重新基于的分支(例如,假设它是master;作为单行命令):gitcheckout-master&&gitpull-origin-master&&gitcheckout-development执行实际的rebase:git rebase-master如果已经完成,并且一切都按预期运行,请将其推到远程。为此,您需要强制它,因为远程主机已经按另一顺序拥有历史记录,所以远程主机将无需推送任何内容。所以,我们需要说“我的本地版本的历史是正确的,使用我的本地历史版本覆盖远程分支上的所有内容”:git push-f origin开发
正如我已经提到的,记住,rebase操纵git历史,这通常是一件坏事。然而,在分支上也可以做到这一点,因为其他人都不承诺这样做。为了让其他开发人员能够使用分支,可以使用另一种合并策略,如合并本身、squash或cherrypick。因此,换句话说:Rebase不应该成为分布式开发的工具。如果您是唯一在这个存储库上工作的人,那么它很适合您。
我们使用特征分支策略。在这种情况下,我通常使用rebase从其他开发人员那里获得“更新”,这是在主分支上同时发生的。这样做可以减少拉取请求中可见的提交大小。因此,代码审阅者更容易看到我在这个特性分支中所做的更改。
如果您在GitHub上创建了一个新的存储库,并意外地用README或.gitignore文件初始化了它。
如果您发现由于.git文件夹损坏而无法合并或重新创建基。
然后:
创建新文件夹git克隆将所有文件粘贴到此文件夹
现在,本地和远程将拥有“相关历史”,并将愉快地合并或重新基础。
我也很挣扎,但我设法找到了解决办法。
当您遇到上面的错误时,只需选择合并提交,然后继续重新启动:
git cherry-pick -m 1 1234deadbeef1234deadbeef
git rebase --continue