随着分布式和开源这些概念的不断普及,现在有大部分的开发者都在用Git管理开源项目、个人项目和公司的项目开发。本篇博客主要是研究实际在使用Git进行多人协作开发过程中的一些场景和解决方案。
引言
Git是一个开源的分布式版本控制系统,可以有效、高速的处理从很小到非常大的项目版本管理。
网上有许多介绍Git的博客等,下面就附上链接:
协同开发场景分析
场景一:开发分支错误
项目来了个需求1
,从develop
分支中拉分支A
进行开发;开发的中途,又来了一个紧急需求2
,于是我就直接在A
分支中开发需求2
;直到发现不能在A
分支中开发需求2
的时候需求2
的代码已经commit
了几次了。
如下图提交:
1 | m1-m2-m3-m4-m5 |
m1、m2、m5是需求1的代码,m3和m4是需求2的代码
解决方案:
假设m3和m4是commit id为0bda20e和1a04d5f
利用cherry-pick和revert:
- 从develop分支创建新分支B:
git checkout B
- 将A分支中的需求2的commit复制到分支B:
git cherry-pick 0bda20e 1a04d5f
- 撤销在A分支中开发的需求2:
git checkout A
和git revert 0bda20e 1a04d5f
附上cherry-pick和revert的一些博客:
场景二:分支进度不一致
1 | m1-m2-m3-m4-m5-m6(master) |
多人协作开发时,你需要开发一个新功能,于是你从master
上的commit3
开始拉了一个分支feature
,可是这个新功能开发周期很长,等到你完成的时候,master
已经提交到m6
了。如上图所示。
解决方案:
使用rebase:
- 切换到分支feature:
git checkout feature
- rebase到master:
git rebase master
- 有冲突解决后执行:
git rebase --continue
分支树则变成(如下图所示)
1 | m1-m2-m3-m4-m5-m6(master) |
附上rebase的一些博客:
暂时先发这么多,到时再补上。有错误的地方麻烦各位指正。谢谢!