设为首页 收藏本站
查看: 1233|回复: 0

[经验分享] gitlab多人协作开发

[复制链接]

尚未签到

发表于 2018-1-10 19:12:48 | 显示全部楼层 |阅读模式
  gitlab多人协同工作
  本文为亨利向《Git权威指南》的作者蒋鑫老师的答疑邮件写成。
  这里特别感谢蒋鑫老师对我询问gitlab的协同工作流程问题的详细解答。
  蒋鑫老师的细致专业的解答让我非常感动。
  gitlab----新颖的git服务器托管网站,开源免费。你可以在自己的公司或者开发团队搭建好一个。
  gitlab的工作流程是
  gitlab help中建议的工作流程是这样。如下图。
DSC0000.jpg

  (1).开发成员拷贝管理员建立好的项目到自己本地。
  (2).创建自己的分支。
  (3).在自己的分支上写代码,并提交。
  (4).推送到远程服务器,分支是自己的分支。
  (分支的命名规则使用小驼峰式命名法。比如我是员工孙悟空,我就推送到孙悟空分支。分支的命名规则为开发人员姓名+所开发的功能。命名中不要使用特殊字符,不要使用点。
  例如孙悟空开发的分支,命名为swkFeature1)
  (5).在Commit页面上浏览分支。
  (6).创建一个合并请求。
  (7).团队的管理员或者领导者审查并且决定是否合并员工提交的分支到主分支上。
  管理员在建好的项目中加入开发人员。
  开发人员有相应的权限级别,分为Guest,Reporter,Developer,Master,等这几个角色,这几个角色的权限从低到高排列。
  Developer能够推送和删除没有保护的分支,Master可以对没有保护和有保护的分支进行操作。如图1所示。
  如下图
DSC0001.jpg

  我们使用下面这个图示中的分支模型进行工作。
  Git 的开发者都喜欢以这种方式来开展工作,在master 分支中保留完全稳定的代码,即已经发布或即将发布的代码。
  与此同时,他们还有一个名为develop 专门用于后续的开发,或仅用于稳定性测试。当然并不是说一定要绝对稳定,不过一旦进入某种稳定状态,
  便可以把它合并到master 里。还有在工作中,把开发任务分解为各个功能或者模块,
  用topic(topic branch主题分支,有又成为feature branch特性分支),实现之后并测试稳定之后,可以合并到其他分支。
DSC0002.jpg

  Git 的开发者都喜欢以这种方式来开展工作,在master 分支中保留完全稳定的代码,即已经发布或即将发布的代码。
  与此同时,他们还有一个名为develop分支 专门用于后续的开发,或仅用于稳定性测试。当然并不是说一定要绝对稳定,
  不过一旦进入某种稳定状态,便可以把它合并到master 里。
  还有在工作中,把开发任务分解为各个功能或者模块,用topic分支(topic branch主题分支,有又称为feature branch特性分支),
  比如实现功能1,在develop分支的基础上产生分支feature1,实现功能2,有分支feature2。
  feature1和feature2实现了要求的功能之后,合并到develop分支上去。develop分支测试稳定之后,可以合并到master分支上去。
DSC0003.jpg

  情景(以下的模拟场景没有把develop分支考虑进去,直接在master分支上分解功能分支。)
  1.管理员唐僧建好了一个项目,把孙悟空加入,并授予Developer角色权限,唐僧本身就是比孙悟空高一级的Master角色。唐僧在自己的电脑上设定好了master分支为受保护分支。
DSC0004.jpg

  2.员工孙悟空在自己电脑上工作,并推送已经写好的代码到远程服务器的孙悟空分支上,即swkFeature1上
DSC0005.jpg

  孙悟空做了如下操作
  git clone git@mygitlabold.sytes.net:root/testc01.git  //从管理员唐僧那里克隆项目
  cd testc01 //进入项目工作
  git checkout -b swkFeature1 //创建自己的分支,并切换到此分支上,分支的命名规则为开发人员名字+所开发的功能名字。本例中命名为swkfeature1
  vim aa.html //写了一个名为aa的html文件
  git add aa.html //加入跟踪
  ggit commit -am "swkFeature1 is ready" //提交
  git push origin swkFeature1 //推送到远程服务器孙悟空分支上,git提示推送成功
  git push origin swkFeature1:master //孙悟空想尝试直接推送到受保护的分支上,孙悟空是没有这个权限的,git会提示为推送失败
  图为孙悟空键入的命令
DSC0006.jpg

  孙悟空在Commit页面上浏览分支swkFeature1,然后向项目领导唐僧创建一个合并请求。
DSC0007.jpg

  3.这个合并请求除了唐僧可以登录gitlab上看到之外,还可以通过邮件方式看到。唐僧即使没有登录gitlab,只要他的邮箱支持手机邮箱等方式,
  手机邮箱可以通过短信的方式通知唐僧,唐僧可以实时看到合并要求。
DSC0008.jpg

  管理员唐僧对要求合并的分支代码进行审核。
  管理员唐僧从服务器上获取孙悟空提交的分支。
  git fetch
  然后孙悟空推送的远程新分支被管理员唐僧拉拽到本地,但是不是以本地分支存在,
  而是保存在 .git/refs/heads 之外(.git/refs/remotes/origin/之中)的远程分支。
  管理员唐僧可以如下方法对孙悟空的分支进行审核。
  执行
  git log master..origin/swkFeature1 //可以看到孙悟空推送了几个提交。
  管理员唐僧可以合并孙悟空的分支:
  git merge origin/swkFeature1
  管理员唐僧可以逐一对孙悟空的提交审核。如果发现有问题,管理员唐僧可以本地回滚。
  git reset --hard HEAD^ # 或 master@{1}
  几个反复后,当孙悟空的分支审核无误,管理员唐僧将合并后的本地 master 分支推送到远程服务器:
  git push # 缺省 remote 为 origin
  图 唐僧在自己的电脑上工作,审核孙悟空提交的分支代码,决定是否合并。
DSC0009.jpg

  图 唐僧键入的命令
DSC00010.jpg

  这个时候,唐僧打开gitlab相应的项目,查看master分支的内容。发现服务器上面有了孙悟空提交的源代码了。
DSC00011.jpg

  唐僧可以在那个请求页面下关闭合并请求。gitlab合并请求有自动的功能,但是还是需要管理员唐僧获取下来,合并,测试是否有问题。不建议使用gitlab的自动合并功能。
DSC00012.jpg

  合并请求就被关闭了。
DSC00013.jpg

  4.孙悟空那边。
  孙悟空看到请求已经接受。
  执行 git fetch 会获取到更新的 master 分支。然后
  git checkout master
  git merge --ff origin/master
  swkFeature1分支完成使命,删掉吧: git branch -d swkFeature1
  图孙悟空后来键入的命令,图中因为没有切换到master分支上,所以又重新执行了一遍上述命令。
DSC00014.jpg

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-433662-1-1.html 上篇帖子: GitLab版本管理工具 下篇帖子: Omnibus Gitlab 502错误
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表