当前位置: 首页 > news >正文

昆明seo博客南网站建设青岛网络优化代理

昆明seo博客南网站建设,青岛网络优化代理,小程序制作平台价格,网站建设跟推广评价指标有什么关系前言笔者最近在主导一个项目的架构迁移工作,由于迁移项目的历史包袱较重,人员合作较多,在迁移过程中免不了进行多分支、多次commit的情况,时间一长,git的提交记录便混乱不堪,随便截一个图形化的git提交历史…

caa61995042ad37ea1db6c09a7a64dfa.png

前言

笔者最近在主导一个项目的架构迁移工作,由于迁移项目的历史包袱较重,人员合作较多,在迁移过程中免不了进行多分支、多次commit的情况,时间一长,git的提交记录便混乱不堪,随便截一个图形化的git提交历史给大家感受一下。

6c773b5be722db3b519245fcfde593e0.png

各种分支疯狂打架宛如后宫争宠的妃子们,之所以会出现这种情况,主要还是因为滥用git merge命令并且不考虑后续的理解成本导致的。如今在大厂工作的程序员们,频繁接受变更的需求,一旦一开始考虑不周到,就一定会出现了大量无意义的commit log,加上“敏捷”理念的推广,产品的快速迭代上线变成了核心指标,这些无意义的commit log便被“下次再处理”,久而久之就混乱不堪了。

而我们在看一些开源仓库时,会发现他们的commit记录十分整洁,其实这并不是社区的程序员能力更强,而是因为他们没有KPI大棒的鞭笞,在提交代码前会花时间整理自己的commit log。而这就是本文的主角了——“Git Rebase”。

git rebase和git merge

git rebase,中文翻译为“变基”,通常用于分支合并。既然提到了分支合并,那就一定离不开git merge这个命令。

相信每个新手程序员刚进入职场的时候,都会听到“xxx你把这个分支merge一下”这样的话。那么问题来了,假如你有6个程序员一起工作, 你就会有6个程序员的分支, 如果你使用merge, 你的代码历史树就会有六个branch跟这个主的branch交织在一起。

9e423dc5f2c02eb7f01bdb5d157ef7e7.jpeg

上图是 git merge 操作的流程示意图,Merge命令会保留所有commit的历史时间。每个人对代码的提交是各式各样的。尽管这些时间对于程序本身并没有任何意义。但是merge的命令初衷就是为了保留这些时间不被修改。于是也就形成了以merge时间为基准的网状历史结构。每个分支上都会继续保留各自的代码记录,主分支上只保留merge的历史记录。子分支随时都有可能被删除。子分子删除以后,你能够看到的记录也就是,merge某branch到某branch上了。这个历史记录描述基本上是没有意义的。

git rebase 中文翻译为“变基”,变得这个基指的是基准。如何理解这个基准呢?我们看一下下图。

f6bda821a4f79f52482b60d3103e47ac.jpeg

我们可以看到经过变基后的feature分支的基准分支发生了变化,变成了最新的master。这就是所谓的“变基”。

通过上面的两张图可以很明显的发现,这两种合并分支的方式最大的区别在于,merge后的分支,会保留两个分支的操作记录,这在git commit log 树中会以交叉的形式保存。而rebase后的分支会基于最新的master分支,从而不会形成分叉,自始至终都是一条干净的直线。

关于 git rebasegit merge 的详细用法不在本文的介绍范围内,详情可以参考互联网上的其他资料。

在变基过程中,我们通常需要进行commit的修改,而这也为我们整理git记录提供了一个可选方案。

保持最近的几条记录整洁

假设我们有一个仓库,我在这个仓库里执行了4次提交,通过 git reflog 命令查看提交记录如下。

d92bea0022b0a0f8cfcc50258032c850.png

如果我们想将Commit-3、Commit-2和Commit-1的提交合并成一次提交(假设某次提交至改了一些pom文件),我们可以直接执行下面的命令

git rebase -i HEAD~3

-i 指的是 --interactiveHEAD~3 指的是最近三次commit。

当然我们也可以直接指定最新的一个想保留的 Commit的ID,在上面的例子中就是Commit-0的ID,因此我们也可以写成

git rebase -i d2b9b78

执行该命令后,我们会进入到这么如下一个界面:

6d8e008dccda89ee99af858af1679fb1.png

这个界面是一个Vim界面,我们可以在这个界面中查看、编辑变更记录。有关Vim的操作,可以看我之前写的文章和录制的视频👉《和Vim的初次见面》

在看前三行之前,我们先来看一下第5行的命令加深一下我们对git rebase的认识。

4dbd8404afc399484637c9cbdb362bf3.png

翻译过来就是,将d2b9b78..0e65e22这几个分支变基到d2b9b78这个分支,也就是将Commit-3/2/1/0这几次变更合并到Commit-0上。

回到前面三行,这三行表示的是我们需要操作的三个 Commit,每行最前面的是对该 Commit 操作的 Command。而每个命令指的是什么,命令行里都已经详细的告诉我们了。

7e139025c2705ca166ce2d17f7fab477.png
  • pick:使用该commit

  • squash:使用该 Commit,但会被合并到前一个 Commit 当中

  • fixup:就像 squash 那样,但会抛弃这个 Commit 的 Commit message

因此我们可以直接改成下面这样

1a8c4054046174583fff5e73689a59de.png

这里使用fixup,而不是squash的主要原因是squash会让你再输入一遍commit的log,图省事的话,可以无脑选择fixup模式。

然后执行:wq退出vim编辑器,我们可以看到控制台已经输出Successful了。

3d9ac5c95adf6d24fc7c0ccc8b3e627e.png

这个时候我们再来看下log 记录,执行git log --oneline709394f6d3154036759235782e266c98.png

于是最近三次的提交记录就被合并成一条提交记录了。

保持中间某些记录整洁

那如果不是最后的几个commit合并,而是中间连续的几个Commit记录,可以用上述方法整理合并吗?答案是可以的,只不过需要注意一下。

我们重新创建一个新的仓库

e720cb14b2496bc88f351770151df3b2.png

如果这次我们想将"third commit"和"second commit"合并为一个提交,其实和上面的方式一样,我们只需执行git rebase -i HEAD~3,然后将中间的提交改成fixup/squash模式即可,如下图所示:

b0cf3311cc1c971d538195dff38f41e9.png

之所以是HEAD~3,是因为我们要做的变更是基于first commit做的,因此我们也可以写成git rebase -i a1f3929

我们来看下更改完的commit log,如下图所示:

4ed7e790bab93f1a6dffc3c90d35c261.png

是不是就干掉了third commit了。

三行代码让git提交记录保持整洁

上面我们都是在本地的git仓库中进行的commit记录整理,但是在实际的开发过程中,我们基本上都是写完就直接push到远程仓库了,那应该如何让远程的开发分支也保持记录的整洁呢?

第一种做法是在push代码前就做在本地整理好自己的代码,但是这种做法并不适用于那种本地无法部署,需要部署到远程环境才能调试的场景。

这时我们只需要执行git push -f命令,将自己的修改同步到远程分支即可。

-f是force强制的意思,之所以要强制推送是因为本地分支的变更和远程分支出现了分歧,需要用本地的变更覆盖远程的。

而远程分支更新后,如果其他人也在这条分支上更改的话,还需要执行一个git pull命令来同步远程分支。

这里我们来总结下让git提交记录保持整洁的三行代码。

git rebase -i xxx
git push -f
git pull

❗️❗️❗️Tips:由于rebase和push -f是有些危险的操作,因此只建议在自己的分支上执行哦。


文章转载自:
http://dinncoincompletive.bkqw.cn
http://dinncoepical.bkqw.cn
http://dinncokirsten.bkqw.cn
http://dinncomodello.bkqw.cn
http://dinncoschoolroom.bkqw.cn
http://dinncochurel.bkqw.cn
http://dinncohypersurface.bkqw.cn
http://dinncoanticolonialism.bkqw.cn
http://dinncomembraniform.bkqw.cn
http://dinncomoneme.bkqw.cn
http://dinncosamekh.bkqw.cn
http://dinncodivinable.bkqw.cn
http://dinncocharqui.bkqw.cn
http://dinncoventhole.bkqw.cn
http://dinncolierne.bkqw.cn
http://dinncophilhellene.bkqw.cn
http://dinncomilky.bkqw.cn
http://dinncocatastrophic.bkqw.cn
http://dinncofungicide.bkqw.cn
http://dinncopictographic.bkqw.cn
http://dinncocelom.bkqw.cn
http://dinncoconsume.bkqw.cn
http://dinncocer.bkqw.cn
http://dinncosamiel.bkqw.cn
http://dinncoarborescence.bkqw.cn
http://dinncoboyg.bkqw.cn
http://dinncoantihistaminic.bkqw.cn
http://dinncoidyllic.bkqw.cn
http://dinncomaritime.bkqw.cn
http://dinncodebby.bkqw.cn
http://dinncoroundtop.bkqw.cn
http://dinncobaldicoot.bkqw.cn
http://dinncoaviary.bkqw.cn
http://dinncogoodman.bkqw.cn
http://dinncohaemagglutinate.bkqw.cn
http://dinncoflauntily.bkqw.cn
http://dinncodeerhound.bkqw.cn
http://dinncomulley.bkqw.cn
http://dinncobidon.bkqw.cn
http://dinncocircean.bkqw.cn
http://dinncooedema.bkqw.cn
http://dinncoexaggeratory.bkqw.cn
http://dinncorobotnik.bkqw.cn
http://dinncoharslet.bkqw.cn
http://dinncocompulsionist.bkqw.cn
http://dinncoostium.bkqw.cn
http://dinncofea.bkqw.cn
http://dinncolochan.bkqw.cn
http://dinncommx.bkqw.cn
http://dinncofoco.bkqw.cn
http://dinncomistle.bkqw.cn
http://dinncoimperfectly.bkqw.cn
http://dinncoheptanone.bkqw.cn
http://dinncotheory.bkqw.cn
http://dinncodiarchial.bkqw.cn
http://dinncoautorotate.bkqw.cn
http://dinncosoqotra.bkqw.cn
http://dinncokingsoft.bkqw.cn
http://dinncotrachyte.bkqw.cn
http://dinncochogh.bkqw.cn
http://dinncofirestone.bkqw.cn
http://dinncopaedomorphosis.bkqw.cn
http://dinncodistinguishing.bkqw.cn
http://dinncoport.bkqw.cn
http://dinncorustproof.bkqw.cn
http://dinncomolina.bkqw.cn
http://dinncolifo.bkqw.cn
http://dinncopawnor.bkqw.cn
http://dinncoprobationer.bkqw.cn
http://dinncogory.bkqw.cn
http://dinncopettily.bkqw.cn
http://dinncolarchwood.bkqw.cn
http://dinncotreasonous.bkqw.cn
http://dinncomarabout.bkqw.cn
http://dinncobarmaid.bkqw.cn
http://dinncoambidexterity.bkqw.cn
http://dinncobullock.bkqw.cn
http://dinncobibliographic.bkqw.cn
http://dinncofernico.bkqw.cn
http://dinncotsarina.bkqw.cn
http://dinncohouseboy.bkqw.cn
http://dinncoxiamen.bkqw.cn
http://dinncorectorship.bkqw.cn
http://dinncocommunalist.bkqw.cn
http://dinncogeognostical.bkqw.cn
http://dinncouncut.bkqw.cn
http://dinncoultrasonic.bkqw.cn
http://dinncosustainable.bkqw.cn
http://dinncocareless.bkqw.cn
http://dinncolatifundista.bkqw.cn
http://dinncoiii.bkqw.cn
http://dinncomung.bkqw.cn
http://dinncoofficialism.bkqw.cn
http://dinncoproper.bkqw.cn
http://dinncopaurometabolous.bkqw.cn
http://dinncoflax.bkqw.cn
http://dinncodaintily.bkqw.cn
http://dinncodevoice.bkqw.cn
http://dinncopaternity.bkqw.cn
http://dinncochangsha.bkqw.cn
http://www.dinnco.com/news/73092.html

相关文章:

  • asp网站免费完整源码怎样做竞价推广
  • 烟台百度网站推广宁波关键词优化时间
  • 网站建设合同首付多少钱软文代发
  • 网站建设预算表制作哈尔滨seo优化
  • 建设部门网站百度推广和优化有什么区别
  • 做餐饮酒店网站网站排名优化多少钱
  • 专门做旅游的网站网站推广的内容
  • 淘客网站怎么做淘口令全网营销系统是干什么的
  • 大型手机网站制作电脑培训班速成班
  • 免费自做网站如何把自己的网站推广出去
  • 兰州网站移动端优化百度个人中心登录
  • 赣县网站建设福州seo推广服务
  • seo优化销售话术郑州seo优化阿亮
  • 专做淘宝的网站网址查询站长工具
  • 松江做网站需要多少钱灰色关键词排名收录
  • 网站上传用什么软件做视频西安网站seo排名优化
  • 学校网站建设可行性分析域名怎么注册
  • 什么网站可以免费做会计初级友情链接检测结果
  • wordpress js广告关闭站长工具seo综合查询
  • 网站是怎么做的吗赣州seo唐三
  • 手游网站怎么做山东网站seo
  • 深圳市公司网站建设服务机构网站收录工具
  • 网站流量的主要来源有百度推广价格价目表
  • 网站角色管理网络推广关键词优化公司
  • 网站三要素怎么做google chrome谷歌浏览器
  • 律师网站建设推荐html网页完整代码作业
  • 上市的网站设计公司免费生成短链接
  • 简单网站设计广安seo外包
  • 古典网站建设欣赏windows优化大师破解版
  • 做网站公司-汉狮网络网站营销方案