【iOS开发笔记】git pull问题的解释和解决方案

一、背景

今天更新了SourceThree,更新后合并代码时遇到了以下问题

hint: Pulling without specifying how to reconcile divergent branches is
hint: discouraged. You can squelch this message by running one of the following
hint: commands sometime before your next pull:
hint:
hint:   git config pull.rebase false  # merge 
hint:   git config pull.rebase true   # rebase
hint:   git config pull.ff only       # fast-forward only
hint:
hint: You can replace "git config" with "git config --global" to set a default
hint: preference for all repositories. You can also pass --rebase, --no-rebase,
hint: or --ff-only on the command line to override the configured default per
hint: 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 参数覆盖缺省设置。

出现问题的主要原因应该是因为更新SourceThree时将git版本也一并更新了,查看后发现git版本为2.37.0

二、相关知识

通过上面的问题提示,可以看到,主要涉及两个Git的配置信息pull.rebasepull.ff

1. pull.ff

  • pull.fffalse时,相当于执行命令git pull --no-ff。这个变量告诉 Git 在这种情况下,如果执行不带选项的git pull命令时先尝试快进合并,如果不行再进行正常合并生成一个新的提交。
  • pull.ffonly时,相当于执行命令git pull --ff-only只允许快进合并,如果执行不带选项的git pull命令时,如果不能进行快进合并则终止当前操作。
  • 如果将pull.ff设置为only,而执行不带选项的git pull命令被终止,其实可以使用带参数的git pull --no-ff或者git pull --rebase命令来执行pull操作。

2. pull.rebase

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

那么git pull命令的各个选项到底有什么意义呢?

3. git pull

  • git pull命令等价于:先执行git fetch,再执行git merge FETCH_HEAD将远程仓库对应分支的最新提交合并到当前本地分支中。
  • git fetch会查询git remote中所有的远程仓库所包含分支的最新提交,并将其记录到.git/FETCH_HEAD文件中。
  • .git/FETCH_HEAD是一个版本链接,指向着目前已经从远程仓库取下来的所有分支的最新提交。

4. git pull的选项及作用

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

综上所述,直接执行git pull时,Git不知道我们到底想要采用哪种合并策略来执行git pull,因此会出现最开始提到的问题,建议我们通过git config来进行基本设置,制定不带任何选项的git pull执行哪种策略。那么下面再讲一下Git的配置。

5. git的配置

5.1 三个配置等级

Git一共有三个配置文件,可以通过git config命令修改,它们的权重为1>2>3,会优先选择--local对应的配置策略进行。

  1. 仓库级配置文件--local
  2. 全局级配置文件--global
  3. 系统级配置文件--system
5.2 查看配置文件

查看配置文件的命令为-l或者采用--list

  1. 查看仓库级的配置:git config --local -l
  2. 查看全局级的配置:git config --global -l
  3. 查看系统级的配置:git config --system -l
  4. 查看当前生效的所有配置:git config -l
5.3 编辑配置文件

编辑配置文件的命令为-e或者采用--edit

  1. 编辑仓库级的配置:git config --local -e
  2. 编辑全局级的配置:git config --global -e
  3. 编辑系统级的配置:git config --system -e
5.4 新增一个配置项

新增配置项的命令为--add,默认添加在--local配置中。其中section.key为要添加的配置项,value是配置项的值。

  1. 新增仓库级的配置项:git config --local --add section.key value
  2. 新增全局级的配置项:git config --global --add section.key value
  3. 新增系统级的配置项:git config --system --add section.key value
5.5 获取一个配置项

获取配置项的命令为--get

  1. 获取仓库级的配置项:git config --local --get section.key
  2. 获取全局级的配置项:git config --global --get section.key
  3. 获取系统级的配置项:git config --system --get section.key
5.6 删除一个配置项

删除配置项的命令为--unset

  1. 删除仓库级的配置项:git config --local --unset section.key
  2. 删除全局级的配置项:git config --global --unset section.key
  3. 删除系统级的配置项:git config --system --unset section.key

6. 其他定义

  • 偏离分支:当本地的分支落后于远程分支时,本地分支又自行修改项目文件生成了新的提交,这时本地分支再执行git pull命令就不能快进合并,并且还容易发生冲突。这时的本地分支便称为偏离分支,因为这时的本地分支的最新提交跟远程分支的最新提交不同,产生了偏离。
  • 合并策略:合并策略便是git merge --ff-onlygit merge --no-ffgit merge --rebase这三种常见的合并策略,分别代表着快进合并非快进普通合并变基合并

三、解决问题

SourceThree的合并代码本质上也是git pull命令,通过上面的学习我们可以了解到,出现问题的原因就是因为git pull的歧义。因此,我们只需要在Git中配置pull.rebasepull.ff的参数即可。

git config --global --add pull.rebase false
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,039评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,223评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,916评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,009评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,030评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,011评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,934评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,754评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,202评论 1 309
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,433评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,590评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,321评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,917评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,568评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,738评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,583评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,482评论 2 352

推荐阅读更多精彩内容