Git问题解决方案:不建议在没有为偏离分支指定合并策略时执行pull操作(Pulling without specifying how to reconcile divergent branches)

2023-05-16

1 问题背景

如果你也在使用2.27.0及以上版本的Git时,使用git pull命令出现以下的警告文案,可以通过阅读本篇文章来解决此问题。

博主最近在Android Studio上使用git pull命令时,每次Android Studio都会弹出下述的警告文案:

warning: Pulling without specifying how to reconcile divergent branches is discouraged. You can squelch this message by running one of the following commands sometime before your next pull:

git config pull.rebase false  # merge (the default strategy)
git config pull.rebase true   # rebase
git config pull.ff only       # fast-forward only

You can replace "git config" with "git config --global" to set a default preference for all repositories. You can also pass --rebase, --no-rebase, or --ff-only on the command line to override the configured default per invocation.

该警告的中文版本文案描述如下:

warning: 不建议在没有为偏离分支指定合并策略时执行pull操作。 
您可以在执行下一次pull操作之前执行下面一条命令来抑制本消息:

git config pull.rebase false  # 合并(缺省策略)
git config pull.rebase true   # 变基
git config pull.ff only       # 仅快进

您可以将 "git config" 替换为 "git config --global" 以便为所有仓库设置
缺省的配置项。您也可以在每次执行 pull 命令时添加 --rebase、--no-rebase,
或者 --ff-only 参数覆盖缺省设置。

当博主看到上述的警告信息后很懵,于是在百度和Google上都查询了相关的问题解释和解决方案,但都没有详细的论证证据和说服力,于是楼主自己前往了Git官方参考文档中查询了相关知识点,终于理清了这个问题,现在把问题产生的原因、解决方案分享给大家。

2 理解问题

2.1 理解问题的文案描述

我们在上述的警告文案描述中可以发现两个重要的Git配置信息pull.rebasepull.ff

先来了解一下pull.ff
在《Git官方文档-参考-pull.ff》文章中可以查看到它的定义:

当把pull.ff设置为false时,这个变量告诉Git在这种情况下,如果执行不带选项的git pull命令时先尝试快进合并,如果不行再进行正常合并生成一个新的提交。


当把pull.ff设置为only时,只允许快进合并(相当于执行命令git pull --ff-only),如果执行不带选项的git pull命令时,如果不能进行快进合并则终止当前操作。


如果将pull.ff设置为only,而执行不带选项的git pull命令被终止,其实可以使用带参数的git pull --no-ff或者git pull --rebase命令来执行pull操作。

接着在《Git官方文档-参考-pull.base》文章中可查看pull.rebase的定义,但是官网的定义过于复杂,因此此处只解释当选项pull.rebase的参数为true或者false时的定义:

pull.rebase为true时,运行不带选项的命令git pull相当于执行git pull --rebase


pull.rebase为false时,运行不带选项的命令git pull不会被改变含义,即不会变基。如果想变基,需要在执行命令时显式地加上选项--rebase,即git pull --rebase

2.2 理解git pull命令的原理及其各选项的含义

2.2.1 git pull命令的原理

git fetch会查询git remote中所有的远程仓库所包含分支的最新提交,并将其记录到.git/FETCH_HEAD文件中。

.git/FETCH_HEAD是一个版本链接,指向着目前已经从远程仓库取下来的所有分支的最新提交。

git pull命令等价于:先执行git fetch,再执行git merge FETCH_HEAD将远程仓库对应分支的最新提交合并到当前本地分支中。

2.2.2 git pull命令中各选项的含义

其中git pull有这几项常见的选项搭配:

  1. 不带任何选项的git pull命令:先尝试快进合并,如果不行再进行正常合并生成一个新的提交。
  2. git pull --ff-only命令:只尝试快进合并,如果不行则终止当前合并操作。
  3. git pull --no-ff命令:禁止快进合并,即不管能不能快进合并,最后都会进行正常合并生成一个新的提交。
  4. git pull --rebase命令:先尝试快进合并,如果不行再进行变基合并。

2.3 理解git pull命令出现问题的原因

现在,看完上述的问题的文案描述、git pull命令的原理及其各选项的含义后,现在我们清楚为什么git pull命令出现该警告文案的原因了:

执行不带任何选项的git pull命令时,会产生三种歧义: git pull --ff-onlygit pull --no-ffgit pull --rebase,而这三种pull方式的合并策略差异很大,即对整个分布式项目的版本管理有很大的影响作用。


而我们执行不带任何选项的git pull命令时,Git就不知道我们到底想用哪种合并策略来执行git pull,因此Git会给出上述的警告文案,建议我们通过git config命令指定不带选项的git pull命令应该按照这三种合并策略的哪种来执行。

3 解决问题

现在我们再次回顾一下上述执行不带选项的git pull命令提示的警告文案:

warning: 不建议在没有为偏离分支指定合并策略时执行pull操作。 
您可以在执行下一次pull操作之前执行下面一条命令来抑制本消息:

git config pull.rebase false  # 合并(缺省策略)
git config pull.rebase true   # 变基
git config pull.ff only       # 仅快进

您可以将 "git config" 替换为 "git config --global" 以便为所有仓库设置
缺省的配置项。您也可以在每次执行 pull 命令时添加 --rebase、--no-rebase,
或者 --ff-only 参数覆盖缺省设置。

首先理解什么是偏离分支

当本地的分支落后于远程分支时,本地分支又自行修改项目文件生成了新的提交,这时本地分支再执行git pull命令就不能快进合并,并且还容易发生冲突。这时的本地分支便称为偏离分支,因为这时的本地分支的最新提交跟远程分支的最新提交不同,产生了偏离。

接着理解什么是合并策略

合并策略便是 git merge --ff-onlygit merge --no-ffgit merge --rebase这三种常见的合并策略,分别代表着快进合并、非快进普通合并、变基合并。

而我们执行不带任何选项的git pull命令时,Git就不知道我们到底想用哪种合并策略来执行git pull,因此Git会给出上述的警告文案,建议我们通过git config命令应该按照这三种合并策略的哪种来执行。

通过上述的文章讲解,现在我们理解了为什么理解git pull命令出现问题的原因,因此只要我们在Git中配置选项pull.rebasepull.ff的参数即可。配置后,即便我们再执行不带任何选项的git pull命令,也不会再出现上述的警告文案啦。

3.1 如何配置选项pull.rebasepull.ff的参数

博主已经在本文的《2.1 理解问题的文案描述》章节中将选项pull.rebasepull.ff的参数的所有情况进行了一一介绍,因此具体怎么配置按照你使用Git的个人喜好即可。

例如博主喜欢在git pull时只接受快进合并和变基合并,那么博主可以执行git config pull.ff only,保证每次执行不带选项的git pull时要么快进合并成功,要么快进合并失败。如果快进合并失败,博主再显式执行git pull --rebase进行变基合并即可。

3.1.1 选项pull.rebasepull.ff各个参数的含义

《Git官方文档-参考-pull.ff》文章中对选项pull.ff各个参数的定义:

当把pull.ff设置为false时,这个变量告诉Git在这种情况下,如果执行不带选项的git pull命令时先尝试快进合并,不行再创建一个合并后新的提交。


当把pull.ff设置为only时,只允许快进合并(相当于执行命令git pull --ff-only),如果执行不带选项的git pull命令时,不能进行快进合并则终止当前操作。


如果将pull.ff设置为only,而执行不带选项的git pull命令被终止,其实可以使用带参数的git pull --no-ff或者git pull --rebase命令来执行pull操作。

《Git官方文档-参考-pull.base》文章中pull.rebase的各个参数的定义:

pull.rebase为true时,运行不带选项的命令git pull相当于执行git pull --rebase


pull.rebase为false时,运行不带选项的命令git pull不会被改变含义,即不会变基。如果想变基,需要在执行命令时显式地加上选项--rebase,即git pull --rebase

3.2 如何保持当前的默认合并策略并阻止弹出警告文案

如果你是一个Git小白,看完我上述的文章还是没看懂什么意思,又希望你自己在执行git pull命令时,既保持当前的默认合并策略,保证不再出现配置合并策略的警告文案,那么你只需要执行git config pull.ff false即可,因为pull.ff默认是没有指定的,而没有指定的pull.ff的默认值与显式指定为false的效果一致。因此当你显式指定pull.ff后,既保持当前的默认合并策略,又能保证不再出现配置合并策略的警告文案。

另外,上述提到的默认策略便是不带任何选项的git pull命令:先尝试快进合并,如果不行再进行正常合并生成一个新的提交。

本文参考文献:
Git warning: Pulling without specifying how to reconcile divergent branches is discouraged
Git官方文档-参考-pull.ff
Git官方文档-参考-pull.base
Git官方文档-参考-git pull
CNBlogs文章《git fetch, git pull 以及 FETCH_HEAD》

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Git问题解决方案:不建议在没有为偏离分支指定合并策略时执行pull操作(Pulling without specifying how to reconcile divergent branches) 的相关文章

  • 我程序人生的启蒙书

    是这本书 xff0c 大一的我接触了c和c 43 43 xff0c 为数学专业的我打开了通往另一个世界的道路 xff0c 做一名优秀的程序员 是这本书 xff0c 大一的我开始废寝忘食的学习 xff0c 自习室里往往就放着这一本数 xff0
  • Leetcode Decode Ways 解题报告

    A message containing letters from A Z is being encoded to numbers using the following mapping 39 A 39 gt 1 39 B 39 gt 2
  • 研究生计算机专业的方向有哪些?

    链接 xff1a https www zhihu com question 349899328 answer 1752872326 编辑 xff1a 深度学习与计算机视觉 声明 xff1a 仅做学术分享 xff0c 侵删 作者 xff1a
  • Android Studio使用OpenCV进行图像基本处理

    Android Studio使用OpenCV进行图像基本处理 1 环境配置 进入OpenCV官网下载SDK包 进入官网 xff08 https opencv org releases xff09 选择 34 Android 34 版本下载
  • QT中基于QWebEngineView的C++和JS互相调用

    QT版本5 14 2 xff0c ubuntu18 04 4 1 PRO包含库 QT 43 61 webenginewidgets 2 main中启用OpenGL QCoreApplication setAttribute Qt AA Us
  • cin相关函数

    cin cin的相关函数 get getline gt gt ignore cin cout 都关联一个行缓冲区 按下enter键 xff0c 生成一个 n 在缓冲区中 xff0c 同时也就可以操作这一行了 cin get 从缓冲区取一个字
  • 浅谈人工智能(AI)

    人工智能 AI 一 人工智能简介 1 1 人工智能定义和发展历史 人工智能 xff08 Artificial Intelligence xff09 xff0c 英文缩写为AI 它是研究 开发用于模拟 延伸和扩展人的智能的理论 方法 技术及应
  • ubuntu18.04忘记密码的解决办法

    大半年没动的U盘系统忘了用户登录密码 xff0c root密码也忘记 xff01 xff01 xff01 xff01 xff01 xff01 xff01 xff01 xff01 xff01 xff01 xff01 简单记录一下 xff0c
  • iocp 非阻塞Socket异步接收限速

    网上找遍了也没找到关于异步非阻塞Socket的限速资料 于是 自己写了一份 限速100M S 误差15M S 限速50M S 误差5M S 限速10M S 误差0 3M S 限速5M S 误差0 02M S 限速越小 精度越准 functi
  • qt发布的程序时如何将依赖的dll分开放在不同目录下

    qt发布的程序时如何将依赖的dll分开放在不同目录下 QT发布的程序 xff0c exe可执行程序与dll文件都在同一个目录下 xff0c 我现在想把那些dll文件 xff0c 放到一个文件夹下 xff0c 这个文件夹和exe在同一个目录下
  • Android性能优化:Bitmap详解&你的Bitmap占多大内存?

    在开发app时 xff0c 显示一张本地图片 xff0c 这张图片在加载时会占用大多内存呢 xff1f 猜测占用内存大小和以下几个因素有关 xff1a 设计师切图 xff0c 图片本身的分辨率 xff1b 图片所放文件夹代表的 密度 dpi
  • HashMap初始容量为什么是2的n次幂及扩容为什么是2倍的形式

    HashMap的初始容量都是2的n次幂的形式存在的 xff0c 而扩容也是2倍的原来的容量进行扩容 xff0c 也就是扩容后的容量也是2的n次幂的形式存在的 xff0c 下面就来说明一下为什么是2的n次幂的形式 xff01 先来看一下源码
  • ARM裸机第五部分-SDRAM和重定位relocate

    第一部分 章节目录 1 5 1 汇编写启动代码之关看门狗 1 5 2 汇编写启动代码之设置栈和调用C语言1 1 5 3 汇编写启动代码之设置栈和调用C语言2 1 5 4 汇编写启动代码之开iCache 1 5 5 重定位引入和链接脚本1 1
  • Java线程死锁的原因和条件

    一 死锁概念 所谓死锁 xff0c 是指多个进程在运行过程中因争夺资源而照成的一种僵局 当进程处于这种僵持状态时 xff0c 若无外力作用 xff0c 它们都将无法再向前推进 二 产生死锁的原因 xff08 1 xff09 竞争资源 当系统
  • Ubuntu 14.04无法连接ssh服务解决方法

    解决方法如下 xff1a 1 先试着开启SSH服务 在使用SSH之前 xff0c 可以先检查SSH服务有没有开启 使用命令 xff1a sudo ps e grep ssh 来查看 xff0c 如果返回的结果是 xxxx 00 00 00
  • 1.14.ARM裸机第十四部分-LCD显示器

    第一部分 章节目录 1 14 1 LCD简介 1 14 2 LCD的接口技术 1 14 3 LCD如何显示图像1 1 14 4 LCD如何显示图像2 1 14 5 LCD的六个主要时序参数1 1 14 6 LCD的六个主要时序参数2 1 1
  • LCD常用接口原理

    LCD常用接口原理 点击打开链接 点击打开链接 点击打开链接 点击打开链接 点击打开链接 点击打开链接 点击打开链接 点击打开链接 xubin 平台信息 内核 xff1a linux2 6 linux3 0 系统 xff1a android
  • 1.15.ARM裸机第十五部分-触摸屏TouchScreen

    第一部分 章节目录 1 15 1 输入类设备简介 1 15 2 电阻式触摸屏的原理 1 15 3 S5PV210的电阻触摸屏控制器 1 15 4 电容触摸屏的原理 1 15 5 ft5x06电容触摸IC简介 第二部分 章节介绍 1 15 1
  • MAC【Android studio】Gradle download:kotlin-compiler-embeddable-1.3.70.jar下载太慢

    采用策略去Maven仓库下载资源 更新到本地进行加载 1 进入仓库网址链接 https mvnrepository com 点击下载如图 2 配置下载jar文件到 gradle文件中 文件路径 Users 34 用户名 34 gradle
  • 线程安全是如何实现的?

    实现线程安全与代码编写有很大的关系 xff0c 但虚拟机提供的同步和锁机制也起到了至关重要的作用 互斥同步 互斥同步 xff08 Mutual Exclusion amp Synchronized xff09 是一种最常见也是最主要的并发正

随机推荐