赞
踩
先以GitLab上的一张经典的图打头,作为一个总体概览,也方便理解分支的管理和走向:
现假设公司有名为Hogwarts_Online2的开发项目,其中包含了上线分支master
,开发分支develop
,测试分支release
,和个人开发的特性分支<feature branch>
#与远程仓库建立连接
git remote add origin ssh://git@47.95.xxx.xx:10022/root/hogwarts_online2.git
#拉取develop分支的文件
git clone -b develop ssh://git@47.95.xxx.xx:10022/root/hogwarts_online2.git
#创建自己的分支
cd hogwarts_online2/
git checkout -b gitflowDemo
gitflowDemo.txt
,输入内容“study git”;然后add
,commit
#修改分支
vi gitflowDemo.txt
#提交修改
git add gitflowDemo.txt
git commit -m "add demo"
git pull
命令检查远程develop分支是否和当前分支有冲突:$ git pull origin develop
From ssh://47.95.238.18:10022/root/hogwarts_online2
* branch develop -> FETCH_HEAD
Already up to date.
注: push之前先拉去远程代码,以防在开发过程中,远程被别人更新过新版本代码。如有代码冲突,两人协商冲突解决办法。多人开发的时候,冲突是不可避免的。
git push
将修改推至远程特性分支origin gitflowDemo
:$ git push origin gitflowDemo
Enumerating objects: 4, done.
Counting objects: 100% (4/4), done.
Delta compression using up to 8 threads
Compressing objects: 100% (2/2), done.
Writing objects: 100% (3/3), 274 bytes | 274.00 KiB/s, done.
Total 3 (delta 1), reused 0 (delta 0)
remote:
remote: To create a merge request for gitflowDemo, visit:
remote: http://47.95.xxx.xx/root/hogwarts_online2/merge_requests/new?merge_request%5Bsource_branch%5D=gitflowDemo
remote:
To ssh://47.95.xxx.xx:10022/root/hogwarts_online2.git
* [new branch] gitflowDemo -> gitflowDemo
merge request
,并在develop分支上进行merge
:如果想要撤回这次merge可用`git merge --abort`
merge
进develop分支中:graph
中查看分支的走向:另外,工作中develop分支可能是权限比较开放的,允许push的,这时候我们就可以在本地直接修改merge然后push到远程develop中
修改gitflowDemo.txt文件为
study git
update
add
,commit
,push
git add gitflowDemo.txt
git commit -m "update gitflowDemo.txt"
git push -u origin gitflowDemo
切换到本地develop
分支,pull
最新代码,merge
本地gitflowDemo
分支代码,push
进远程develop
分支
git checkout develop
git pull origin develop
git merge gitflowDemo
git push -u origin develop
这个是在GitLab上检查更新情况:
develop
分支变动频繁,master
分支属于上限版本,因此需要一个内测的分支版本,这个就是release
分支了
具体的提交操作根据权限范围,和1中develop的操作一致。
有的时候出现的非常紧急的bug,需要立即修改上线,来不及在各个分支上进行merge
测试了;这个就是就需要用hotfixes
模式,建立一个bugfix
分支,直接绕开其他分支,修改合并到master
中。
注: 这种未经测试就上线的情况很危险,本人就遇见过;之前驻场在华为里工作的时候,组内一位开发同事修改了一两行的代码,觉得不会有问题就直接跳过了我们测试,通过别人直接上线发布了,当时我所在的组是GNSS组;结果直接导致一千多万台手机的定位功能有失效的风险,受到了很多投诉,影响很大;最终相关开发人员被紧急停止休假,我们测试组也十一加了七天班,为了这个小小的改动付出了不小的后果~
git checkout master
git checkout -b bug_02fix
vi bugfix02.txt
fix bug02
git commit -a -m "bug_01 fix"
git push -u origin bug_01fix
git add bugfix02.txt
git commit -m "fix bug02"
git push origin bug_02fix
master
分支拉出来的修改bug02的分支:master
权限拥有者来进行合并。master
后,很有可能让master
分支的修改已经领先其他分支了;这个时候就需要将其他分支更新,对master
分支进行合并;同时将bugfix分支删除,尽量保证分支的整洁度。git log --graph --all --decorate=short
git grep "pattern" $(git rev-list --all)
git log f13297
变基,合并分支后可以将分支走向的基准线变更,在分支很多的时候,可以简化分支的展示,合并分支走向使流程看起来简洁一点
git checkout feature
git rebase master
与merge后的分支走向对比:
git checkout feature
git merge master
#或者写在一行
git merge feature master
此外,rebase还可以对提交的历史进行修改(不常用也不建议使用)
git rebase -i HEAD~2
注意: rebase的使用规则
1、不要在公用的分支上执行rebase
2、主要的分支进行保护
git diff
git diff HEAD~3
git diff master develop
常见diff工具:
vimdiff bugfix01.txt bugfix02.txt
参考链接:
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。