如何避免git pull时产生Merge branch master of等类似操作
如默
撰写于 2019年 10月 15 日

介绍

如题,在使用 Git 的进行代码版本控制的时候,往往会发现在 log 中出现 “Merge branch ‘master’ of …” 这句话,如下图所示。日志中记录的一般为开发过程中对代码的改动信息,如果出现过多例如上述描述的信息会造成日志的污染。

如图,此图为VS code中git history插件图

git history

git history

可以看到主分支不干净,节点很多、很乱

产生的原因

当多人合作开发一个项目时,本地仓库落后于远程仓库是一个非常正常的事情,可参考下图。

A-B-C(master)
\
D(origin/master)

具体情境如下:

我当前拉取的远端版本为 B,此时修改了代码,并在本地仓库 commit 一次,但并未 push 到远端仓库。 另一位开发者在 B 的基础上,同样 commit 了一次并 push 到远端仓库。那么这个时候,我再 push 自己的代码就会发生错误

这个时候我们会选择,先 pull,再 push。Ok,push 成功,但是此时我们查看 log 就会发现除了我们自己提交的那条日志之外,会多出一条 “Merge branch ‘master’ of …”。

那么,为什么会出现这种现象呢?其实是与 Git 的工作原理有关,对 Git 比较了解的人应该会知道,无论是 pull、push 亦或是 merge 操作,其实背后都是有很多的不同的模式的。

在进行 pull 操作的同时,其实就是 fetch+merge 的一个过程。我们从 remote 分支中拉取新的更新,然后再合并到本地分支中去。

如果 remote 分支超前于本地分支,并且本地分支没有任何 commit 的,直接从 remote 进行 pull 操作,默认会采用 fast-forward 模式,这种模式下,并不会产生合并节点,也就是说不会产生多余的那条 log 信息 如果想之前那样,本地先 commit 后再去 pull,那么此时,remote 分支和本地会分支会出现分叉,这个时候使用 pull 操作拉取更新时,就会进行分支合并,产生合并节点和 log 信息。这两种状态分别如下所示:

# fast-forword 
A-B-D(origin/master)
     \
      C(master)
# merge
A-B-C-E(master)
   \ /
    D(origin/master)

如何解决

通过百度,包括自己的实践,有三种方法

方法1

在执行git pull的时候加上--rebase参数,成功后在进行真正的merge操作。(如果有冲突需要手动解决)

方法2

这个方法操作以后可以一劳永逸。在你的 git bash 里执行git config --global pull.rebase true,这个配置就是告诉 git 在每次 pull 前先进行 rebase 操作。这种方法和方法1原理一样,只不过方法1是每次pull前都要手动操作。

方法3

不建议直接pull操作,建议在commit之后,先fetch一下,然后merge合并,最后执行 push命令

总结

rebase 使用不好会在 git bash 顶部出现(master|REBASE 1/1),此时执行git rebase --abort即可恢复
rebase 操作的的好处是你们团队的 commit message 时间线会成一条笔直的直线

如何避免git pull时产生Merge branch master of等类似操作

温馨提示:

本文最后更新于2019年10月15日,已超过1932天没有更新,若内容或图片失效,请留言反馈。

介绍

如题,在使用 Git 的进行代码版本控制的时候,往往会发现在 log 中出现 “Merge branch ‘master’ of …” 这句话,如下图所示。日志中记录的一般为开发过程中对代码的改动信息,如果出现过多例如上述描述的信息会造成日志的污染。

如图,此图为VS code中git history插件图

git history

git history

可以看到主分支不干净,节点很多、很乱

产生的原因

当多人合作开发一个项目时,本地仓库落后于远程仓库是一个非常正常的事情,可参考下图。

A-B-C(master)
\
D(origin/master)

具体情境如下:

我当前拉取的远端版本为 B,此时修改了代码,并在本地仓库 commit 一次,但并未 push 到远端仓库。 另一位开发者在 B 的基础上,同样 commit 了一次并 push 到远端仓库。那么这个时候,我再 push 自己的代码就会发生错误

这个时候我们会选择,先 pull,再 push。Ok,push 成功,但是此时我们查看 log 就会发现除了我们自己提交的那条日志之外,会多出一条 “Merge branch ‘master’ of …”。

那么,为什么会出现这种现象呢?其实是与 Git 的工作原理有关,对 Git 比较了解的人应该会知道,无论是 pull、push 亦或是 merge 操作,其实背后都是有很多的不同的模式的。

在进行 pull 操作的同时,其实就是 fetch+merge 的一个过程。我们从 remote 分支中拉取新的更新,然后再合并到本地分支中去。

如果 remote 分支超前于本地分支,并且本地分支没有任何 commit 的,直接从 remote 进行 pull 操作,默认会采用 fast-forward 模式,这种模式下,并不会产生合并节点,也就是说不会产生多余的那条 log 信息 如果想之前那样,本地先 commit 后再去 pull,那么此时,remote 分支和本地会分支会出现分叉,这个时候使用 pull 操作拉取更新时,就会进行分支合并,产生合并节点和 log 信息。这两种状态分别如下所示:

# fast-forword 
A-B-D(origin/master)
     \
      C(master)
# merge
A-B-C-E(master)
   \ /
    D(origin/master)

如何解决

通过百度,包括自己的实践,有三种方法

方法1

在执行git pull的时候加上--rebase参数,成功后在进行真正的merge操作。(如果有冲突需要手动解决)

方法2

这个方法操作以后可以一劳永逸。在你的 git bash 里执行git config --global pull.rebase true,这个配置就是告诉 git 在每次 pull 前先进行 rebase 操作。这种方法和方法1原理一样,只不过方法1是每次pull前都要手动操作。

方法3

不建议直接pull操作,建议在commit之后,先fetch一下,然后merge合并,最后执行 push命令

总结

rebase 使用不好会在 git bash 顶部出现(master|REBASE 1/1),此时执行git rebase --abort即可恢复
rebase 操作的的好处是你们团队的 commit message 时间线会成一条笔直的直线


赞 (0)

猜您想看

  • 个人网站ICP备案指南

    网站想要在互联网上正常访问,是需要备案的,备案就是上户口,登记。

    2019年01月22日
  • 二进制安装和Docker安装Gitea的SSH配置

    前面两天使用了Gitea,发现使用ssh协议克隆有点问题,特此记录。

    2022年12月01日
  • CentOS7下Docker安装Gitea配合宝塔面板实现反代

    前几天用二进制安装了Gitea,过程有些繁琐,而且配置SSH也比较麻烦,现在用Docker安装一下,特此记录。

    2022年11月29日
  • 华为MateView 28.2显示器一周评测

    前两天之前买的AOC显示器出了一点故障,总是无法识别主机信号,动不动就无信号了,送回京东自营换新了,临时买了一个华为的显示器顶几天,发现了很多问题,分享一下。

    2023年01月23日
  • Docker指定latest标签

    之前发布了两个版本的docker文件,有1.0和2.0,默认使用latest标签应该指向最新的2.0版本,记录一下

    2023年05月30日
  • 迁移Git项目

    之前使用的是GitHub和Gitee,国外的访问速度太慢,国内的又各种限制,所以自己搭建了一个Gitea,用来存放代码,之前的仓库不想丢失log记录等信息,所以需要迁移,特此记录。

    2022年11月29日

评论区(暂无评论)

这里空空如也,快来评论吧~

我要评论

Vaptcha 初始化中...