为什么Git不允许我快进合并了?如果我试图使用——ff-only强制它,我会得到消息“致命:不可能快进,终止。”我意识到合并-no-ff有巨大的优势,但我只是不明白为什么我现在不能-ff-only ?
当前回答
如果您在本地分支上执行git pull origin master时遇到此情况,请在记事本中打开.gitconfig(通常隐藏在C:\Users\Myname中)并添加这两行
[pull]
ff = no
保存配置并再次尝试git pull origin master
其他回答
如果原始分支被压缩,或者有一个更改破坏了提交历史,如果你不关心本地分支提交历史,你可以重置本地分支
git checkout branchname
git reset --hard origin/branchname
使用选项——no-ff关闭一次快进:
git pull --no-ff
https://git-scm.com/docs/git-pull#Documentation/git-pull.txt---no-ff
这是因为您启用了“仅快进”选项。这里的问题是你从分支的拉取会在你的本地git中创建一个合并提交,而只有快进选项不允许在拉取时创建一个合并提交。
在一个大团队的情况下,你最终会在很多时候改变和解决冲突,因为每一个承诺都来自拉力。
我建议你从git本地配置文件中删除ff = only行。
$ CD到我的项目根目录
纳米美元
[pull]
ff = only // remove this line
rebase = false
免责声明:这些命令将从远程分支到您的分支中带来更改。
快拉,变基。与其他解决方案不同,您不需要知道目标分支的名称。
如果你的上游分支没有设置,尝试git拉origin <branch>—rebase(在评论中归功于@Rick)
要全局设置这个选项,使用git config——global pull。rebase true(归功于@Artur Mustafin)
这对我很有用
git pull --rebase <remote> <branch>
推荐文章
- 为什么我需要显式地推一个新分支?
- 如何撤消最后的git添加?
- Rubymine:如何让Git忽略Rubymine创建的.idea文件
- Gitignore二进制文件,没有扩展名
- Git隐藏错误:Git隐藏弹出并最终与合并冲突
- 了解Git和GitHub的基础知识
- 没有。Git目录的Git克隆
- Git与Mercurial仓库的互操作性
- 忽略git中修改(但未提交)的文件?
- “git restore”命令是什么?“git restore”和“git reset”之间有什么区别?
- Git合并与强制覆盖
- Git拉另一个分支
- 在Bash命令提示符上添加git分支
- 如何更改Git日志日期格式
- git pull -rebase和git pull -ff-only之间的区别