开发人员必知的Git技能及Git工作流总结!(四)

简介: 大家好,我是指北君。PS:最近是跳槽的高峰期,我连日加班好多天,整理出了包含16000 多道面试题的面试宝典,并且指北君也会持续更新这份面试宝典中的题目,希望它能帮助大家找到自己心仪的工作!【文末有领取方式】

1.6 log & show

查看最近的5次提交,按Q就直接退出。


50.png

使用ASCII图形表示分支合并历史

51.png

显示最近5次提交的详细内容

52.png


2 Git Work Flow


2.1 Centralized Workflow

Centralized WorkFlow 这种模式对比熟悉SVN的开发人员比较容易适应。在Git 远程仓库有一个主分支,开发人员也在自己的本地克隆了一个完全一样的分支,开发人员可以在本地的分支上随意的进行代码编写,测试。当完成当前开发工作之后,可以直接push到远程主分支上。就算是有冲突也可以快速的解决。

中心仓库式工作流对于小型开发团队比较适用,人员少,改动也就相对比较少,出现冲突的几率也要少很多。就算是有冲突,合并也不会有太大问题。显然这种工作方式却不适合大型团队,几个开发组同时开发维护一个项目,这样代码会非常混乱,每个人的提交都会影响其他组开发的工作。如果再有不同组的开发任务上线时间点不一样,那么就是一场灾难。


2.2 Feature Branch Workflow

基于Feature Branch WorkFlow 的Git工作流,其基于一个中心仓库,主分支(也可以是其他的生产代码分支)代表了项目历史。每次有新的开发任务的时候,基于主分支新创建一个Feature分支,和当前任务相关的代码都提交的这个Feature分支。

当开发工作进行到一定阶段,就可以提一个Pull Request代主分支,这个时候就可以让同事去Review自己的代码了。此时Review阶段可能会有一些小问题,或者同事给出了更好的建议,我们都可以针对性的修改代码。

最后让测试等工作都完成之后,就可以将Feature 分支合并到主分支上。最终测试完成之后就可以部署到生产上面。之后Feature分支可以视情况删除,或者保留一段时间之后再删除。


2.3 GitFlow WorkFlow

GitFlow WorkFlow是一种比较经典的工作模式。

其主要有如下的一些分支协作。

Main/Master Branch (主分支):维护着项目的历史记录,会记录每一次上线的标签,并且可以看到每一次上线的一些新特性等。

Develop Branch(开发分支):基于主分支,主要是为了下一次上线所使用的开发分支,可以接受Feature分支的Pull Request。当所有的新特性都已经合并完毕,那么就创建。

Release Branch(部署分支):当开发分支已经合并了足够的特性分支代码之后,会创建一个Release分支。此时Release分支不会接受任何Feature分支的Pull Request,仅接受一些Bug fix的Pull Request。Release分支部署上线之后,测试全部通过后会将代码合并到Develop 分支和主分支。

Feature Branch(特性分支):一般会基于开发分支创建出一条针对某个功能的分支,开发人员会基于这条分支进行开发和单元测试的工作,当本Feature开发完成之后。会将代码合并到Develop分支上,之后可以选择适时删除次分支。

Hotfix Branch(修补分支):针对与线上出现的紧急问题,从主分支,也就是上一次上线的标签出创建一个Hotfix 分支。当问题解决之后,可能会有一次紧急的上线来解决之前发现的问题。当问题解决之后,会将代码合并到主分支,和开发分支。以便下一次上线也会包含本次的紧急修复代码。

Support Branch(备用支撑分支):这个分支的应用比较灵活,有时候如果项目上线的时候基于各种可能性, (比如某个依赖的系统上线失败,或者其他不必要的特性上线失败) 可能会需要准备多个版本,那么Support Branch 就可以作为一条备用分支来使用。这个分支可以根据项目的实际情况来看是否需要使用!

各个Branch的示例关系可以看下图53.jpg

我们也可以使用git flow 的一些命令来使用这个工作模式,会有一些既有的命令,使用起来会比较规范,但是也会有一定复杂,项目中可以根据实际情况使用!


54.jpg

git flow 相关的一些命令

55.jpg

2.4 Forking Workflow

Forking WorkFlow 相对与上面的几种协同工作方式有较大的不同。

其主要公共远程仓库私人远程仓库,和本地仓库

开发人员一般会从公共远程仓库Fork一份完全一样的代码仓库到自己的私人远程仓库。对于私人远程仓库来说,开发人员是拥有者,拥有所有的权限。开发人员可以在本地仓库提交之后随时push到自己的私人远程仓库,随时进行Revert、Reset、Rebase等操作。

公共远程仓库为项目的组织官方仓库,保留有不同的分支,以及标签等。可以由私人远程仓库提交Pull Request到公共远程仓库的某个分支,待同事或者一些Owner Review过之后,就可以合并到公共仓库。

Forking WorkFlow 也是比较推荐的一种方式,开发人员push代码之后,可以随时在自己的提交基础之上进行Rebase操作,合并之前的许多提交,这样提交历史比较整洁,同时Review也比较方便。

3 Git 常见问题及处理方法以及建议。

  1. 使用Github合并PullRequest的时候,如果代码有冲突,通过网页解决冲突合并之后。Github会进行双向合并
  2. 关于Git协作,可以考虑Git Flow与Feature flow 还有Forking flow结合使用,Forking Flow有利于整理提交历史,Feature branch对于代码的管理比较友善。
  3. 本地的代码跑完一次测试的时候就可以提交一版,然后在需要push的时候在rebase合并一次。尽量完善自己的commit信息,写好每一次提交记录。
  4. 如果merge有问题可以使用git merge --abort 解除merge, 然后再重新合并。
  5. 多使用Git命令行来进行日常的提交等工作,有助于更好的理解Git的工作原理,这样在不同的IDE上都能比较容易的使用Git插件了。

总结

选择什么样的Git工作流,什么样的工作流最适合自己的团队呢。

其实关于这个问题有如下的几个方面可以值得考虑:

  1. 当前选择的团队协作方式是不是可扩展性的,随着团队的大小变化,都可以比较容易适应团队。
  2. 当前的工作流相比于其他的形式,可不可以更容易的发现和避免错误,比如Review是否有效。
  3. 当前选择的工作流对于团队工作来说需要额外花费多少精力,是不是会浪费一些不必要的精力。

面试大全包括:包括 Java 集合、JVM、多线程、并发编程、设计模式、SpringBoot、SpringCloud、Java、MyBatis、ZooKeeper、Dubbo、Elasticsearch、Memcached、MongoDB、Redis、MySQL、RabbitMQ、Kafka、Linux、Netty、Tomcat、Python、HTML、CSS、Vue、React、JavaScript、Android 大数据、阿里巴巴等大厂面试题等、等技术栈!


我是指北君,操千曲而后晓声,观千剑而后识器。感谢各位人才的:点赞、收藏和评论,我们下期更精彩!

相关文章
|
4月前
|
存储 算法 开发工具
Git - 分支基本实践总结与工作流原理
Git - 分支基本实践总结与工作流原理
63 0
|
11月前
|
前端开发 测试技术 持续交付
基于 Git 的开发工作流——主干开发特性总结
基于 Git 的开发工作流——主干开发特性总结
185 0
|
IDE 程序员 开发工具
一文搞懂Git工作流,再也不用担心入职就被辞退了
前言 之前在看到这句话的时候,我刚实习入职不久,瑟瑟发抖。好巧不巧,今天又看到了类似的文章讲git重要性的。
157 0
一文搞懂Git工作流,再也不用担心入职就被辞退了
|
Shell 网络安全 开发工具
git使用问题总结
git使用问题总结
134 0
git使用问题总结
|
网络安全 开发工具 git
Git常用语法总结及分支冲突
Git常用语法总结及分支冲突
111 0
|
测试技术 开发工具 git
git协作工作流方式
作为项目代码版本管理,在团队中不同成员工作成果合并并发布的方式不同,对分支的使用(工作流)也不同
106 0
|
开发工具 git
Git分支管理和常见的分支工作流
利用分支的两种典型工作流: master分支用来管理稳定发布版本的代码; 另外搞个平行分支 develop用于管理测试版本、不稳定代码 测试通过,将develop分支合并进master分支 topic branch:为了一个新功能、新想法,你可以临时随心所欲的开新分支。
101 0
|
缓存 安全 Unix
【知识】团队开发技能: Git
【知识】团队开发技能: Git
109 0
【知识】团队开发技能: Git
|
数据可视化 安全 Unix
【Git|GitHub|SSH|Sourcetree 下篇】GitHub|Sourcetree|SSH部署及Git-flow工作流
GitHub|Sourcetree|SSH快速部署、git-flow工作流、Remote Repository的克隆和推送
224 0
【Git|GitHub|SSH|Sourcetree 下篇】GitHub|Sourcetree|SSH部署及Git-flow工作流
|
开发工具 git
git简单总结
git简单总结

相关实验场景

更多