在git重新启动/开发过程中,git显示以下错误消息:

fatal: refusing to merge unrelated histories
Error redoing merge 1234deadbeef1234deadbeef

我的Git版本是2.9.0。它在以前的版本中运行良好。

我如何才能继续使用新版本中引入的强制标志来允许不相关的历史?


当前回答

请尝试以下命令:

git pull origin master --allow-unrelated-histories

这应该能解决你的问题。

其他回答

这通常发生在您第一次提交到远程存储库时。正如错误明确指出的“拒绝合并不相关的历史”,我们需要使用--allow不相关历史标志。

git pull origin master  --allow-unrelated-histories

现在会有一些冲突,我们必须手动解决。之后,只需提交代码并推送它。

您可以使用--允许不相关的历史记录强制合并。

这背后的原因是自Git 2.9以来,默认行为发生了变化:

“gitmerge”用于合并两个没有公共项的分支默认情况下,这导致了现有项目被创建,然后被一个不知情的维护人员拉住,这允许将不必要的并行历史合并到现有项目。命令已被教导不允许这样做默认情况下,带有转义线--允许不相关的历史记录选项用于合并两个项目历史的罕见事件独立开始他们的生活。

有关更多信息,请参阅Git发布变更日志。

更多信息可以在这个答案中找到。

通过切换“允许无关历史记录”开关来解决该错误。在Git pull或Git merge命令后,添加以下标记:

git pull origin master --allow-unrelated-histories

之后,也许你会有冲突。所以,解决冲突,并付诸实施。这对我很有用。

请尝试以下命令:

git pull origin master --allow-unrelated-histories

这应该能解决你的问题。

我也有同样的问题。试试看:

git pull origin master --allow-unrelated-histories 

git push origin master