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

专业的网站建设服务商建设银行官方网站地址

专业的网站建设服务商,建设银行官方网站地址,erp系统定制,建设网站号码是多少前言笔者最近在主导一个项目的架构迁移工作#xff0c;由于迁移项目的历史包袱较重#xff0c;人员合作较多#xff0c;在迁移过程中免不了进行多分支、多次commit的情况#xff0c;时间一长#xff0c;git的提交记录便混乱不堪#xff0c;随便截一个图形化的git提交历史…前言笔者最近在主导一个项目的架构迁移工作由于迁移项目的历史包袱较重人员合作较多在迁移过程中免不了进行多分支、多次commit的情况时间一长git的提交记录便混乱不堪随便截一个图形化的git提交历史给大家感受一下。各种分支疯狂打架宛如后宫争宠的妃子们之所以会出现这种情况主要还是因为滥用git merge命令并且不考虑后续的理解成本导致的。如今在大厂工作的程序员们频繁接受变更的需求一旦一开始考虑不周到就一定会出现了大量无意义的commit log加上“敏捷”理念的推广产品的快速迭代上线变成了核心指标这些无意义的commit log便被“下次再处理”久而久之就混乱不堪了。而我们在看一些开源仓库时会发现他们的commit记录十分整洁其实这并不是社区的程序员能力更强而是因为他们没有KPI大棒的鞭笞在提交代码前会花时间整理自己的commit log。而这就是本文的主角了——“Git Rebase”。git rebase和git mergegit rebase中文翻译为“变基”通常用于分支合并。既然提到了分支合并那就一定离不开git merge这个命令。相信每个新手程序员刚进入职场的时候都会听到“xxx你把这个分支merge一下”这样的话。那么问题来了假如你有6个程序员一起工作 你就会有6个程序员的分支 如果你使用merge, 你的代码历史树就会有六个branch跟这个主的branch交织在一起。上图是 git merge 操作的流程示意图Merge命令会保留所有commit的历史时间。每个人对代码的提交是各式各样的。尽管这些时间对于程序本身并没有任何意义。但是merge的命令初衷就是为了保留这些时间不被修改。于是也就形成了以merge时间为基准的网状历史结构。每个分支上都会继续保留各自的代码记录主分支上只保留merge的历史记录。子分支随时都有可能被删除。子分子删除以后你能够看到的记录也就是merge某branch到某branch上了。这个历史记录描述基本上是没有意义的。而 git rebase 中文翻译为“变基”变得这个基指的是基准。如何理解这个基准呢我们看一下下图。我们可以看到经过变基后的feature分支的基准分支发生了变化变成了最新的master。这就是所谓的“变基”。通过上面的两张图可以很明显的发现这两种合并分支的方式最大的区别在于merge后的分支会保留两个分支的操作记录这在git commit log 树中会以交叉的形式保存。而rebase后的分支会基于最新的master分支从而不会形成分叉自始至终都是一条干净的直线。关于 git rebase 和 git merge 的详细用法不在本文的介绍范围内详情可以参考互联网上的其他资料。在变基过程中我们通常需要进行commit的修改而这也为我们整理git记录提供了一个可选方案。保持最近的几条记录整洁假设我们有一个仓库我在这个仓库里执行了4次提交通过 git reflog 命令查看提交记录如下。如果我们想将Commit-3、Commit-2和Commit-1的提交合并成一次提交假设某次提交至改了一些pom文件我们可以直接执行下面的命令git rebase -i HEAD~3-i 指的是 --interactive HEAD~3 指的是最近三次commit。当然我们也可以直接指定最新的一个想保留的 Commit的ID在上面的例子中就是Commit-0的ID因此我们也可以写成git rebase -i d2b9b78执行该命令后我们会进入到这么如下一个界面这个界面是一个Vim界面我们可以在这个界面中查看、编辑变更记录。有关Vim的操作可以看我之前写的文章和录制的视频《和Vim的初次见面》在看前三行之前我们先来看一下第5行的命令加深一下我们对git rebase的认识。翻译过来就是将d2b9b78..0e65e22这几个分支变基到d2b9b78这个分支也就是将Commit-3/2/1/0这几次变更合并到Commit-0上。回到前面三行这三行表示的是我们需要操作的三个 Commit每行最前面的是对该 Commit 操作的 Command。而每个命令指的是什么命令行里都已经详细的告诉我们了。pick使用该commitsquash使用该 Commit但会被合并到前一个 Commit 当中fixup就像 squash 那样但会抛弃这个 Commit 的 Commit message因此我们可以直接改成下面这样这里使用fixup而不是squash的主要原因是squash会让你再输入一遍commit的log图省事的话可以无脑选择fixup模式。然后执行:wq退出vim编辑器我们可以看到控制台已经输出Successful了。这个时候我们再来看下log 记录执行git log --oneline于是最近三次的提交记录就被合并成一条提交记录了。保持中间某些记录整洁那如果不是最后的几个commit合并而是中间连续的几个Commit记录可以用上述方法整理合并吗答案是可以的只不过需要注意一下。我们重新创建一个新的仓库如果这次我们想将third commit和second commit合并为一个提交其实和上面的方式一样我们只需执行git rebase -i HEAD~3然后将中间的提交改成fixup/squash模式即可如下图所示之所以是HEAD~3是因为我们要做的变更是基于first commit做的因此我们也可以写成git rebase -i a1f3929我们来看下更改完的commit log如下图所示是不是就干掉了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://www.hkea.cn/news/14437009/

相关文章:

  • 点击量高的网站动力网站建设
  • vi设计公司排行seo网站页面诊断
  • wordpress屏蔽自带密码重置爱网站推广优化
  • 餐厅网站建设策划方案wordpress网址导航页面
  • 凡科 预约网站百度招聘
  • python网站开发集成环境友链交换网站
  • 一个网站能用asp c整站优化费用
  • 建材 网站 模板wordpress学习pdf
  • 企业网站cms系统论文王展简历
  • 免费模板建设网站小程序电商系统开发
  • 做电影网站的服务器需要多大惠州网站建设html5
  • 电商商城网站建设业务管理系统
  • 网站建设与网页设计实训报告宁波网站建设公司哪家最正规
  • 建设网站内容的策划书重庆建设传动科技有限公司
  • 文案策划网站电商平台运营公司
  • 比较好的网站建设技术开发网站建设私人合同范本
  • 男女做爰高清免费网站设计网页心得体会
  • 网站如何做词wordpress超简洁主题
  • 成都高标建设有限公司官方网站电商网站哪家做的好
  • 衡水网站建设套餐苏州手机网站开发公司
  • 工艺品东莞网站建设素材网站模板
  • 青岛优化网站关键词用哪个程序做网站收录好6
  • 加盟网站模板wordpress顶部通知栏
  • 网站建设次年续费合同口碑好网站建设电话
  • 郑州h5网站建设价格简述网站建设主要流程
  • 响应式网站微博视频杭州外贸网站建设公司排名
  • 青海西宁学做网站在哪做汽车配件外贸用什么网站
  • 网站运营需要什么行业技术熟悉网页设计人机交互实验报告
  • 临沂网站建设哪家好莘县网站建设
  • 文安做网站急切网