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

[经验分享] 使用Git进行协同开发

[复制链接]

尚未签到

发表于 2018-1-16 10:56:57 | 显示全部楼层 |阅读模式
  用了一段时间github,一直想用时间来对git的使用来做一段笔记,前段时间比较忙,现在沉下心来学习也是极好的。
  很多项目开发会采用git这一优秀的分布式版本管理工具来进行项目版本管理。因为git的使用非常灵活,所以在实际操作中会有许多不同的工作流程。不同团队对于不同项目会有不同的协作方式。掌握git版本管理开发,对以后的学习和开发都有很多好处。
  首先基本名词要懂:
  仓库(Repository)、分支(branch)、工作流(workflow)
  1. 仓库(Repository)
  在项目的开始到结束,我们会有两种仓库。一种是源仓库(origin),一种是开发者仓库。
  源仓库(origin)的有两个作用:

  •   汇总参与该项目的各个开发者的代码
  •   存放趋于稳定和可发布的代码
  源仓库应该是受保护的,开发者不应该直接对其进行开发工作。只有项目管理者(通常是项目发起人)能对其进行较高权限的操作。
  开发者仓库:
  任何开发者都不会对源仓库进行直接的操作,源仓库建立以后,每个开发者需要做的事情就是把源仓库的“复制”一份,作为自己日常开发的仓库。这个复制,也就是github上面的fork。
  每个开发者所fork的仓库是完全独立的,互不干扰,甚至与源仓库都无关。  每个开发者仓库相当于一个源仓库实体的影像,  开发者在这个影像中进行编码, 提交到自己的仓库中,这样就可以轻易地实现团队成员之间的并行开发工作。  而开发工作完成以后,   开发者可以向源仓库发送pull request,请求管理员把自己的代码合并到源仓库中,这样就实现了分布式开发工作,和最后的集中式的管理。
  2. 分支(branch)
  在git中,分支操作则是每个开发人员日常工作流。利用git的分支,可以非常方便地进行开发和测试。
  我们为git定下一种分支模型,在这种模型中,分支有两类,五种:

  •   永久性分支

    •   master branch:主分支
    •   develop branch:开发分支

  •   临时性分支

    •   feature branch:功能分支
    •   release branch:预发布分支
    •   hotfix branch:bug修复分支

  master:主分支从项目一开始便存在,它用于存放经过测试,已经完全稳定代码;在项目开发以后的任何时刻当中,master存放的代码应该是可作为产品供用户使用的代码。每一次master更新的时候都应该用git打上tag,说明你的产品有新版本发布了。
  develop:开发分支,一开始从master分支中分离出来,用于开发者存放基本稳定代码。开发者把功能做好以后,是存放到自己的develop中,当测试完以后,可以向管理者发起一个pull request,请求把自己仓库的develop分支合并到源仓库的develop中。
  归纳:所有开发者开发好的功能会在源仓库的develop分支中进行汇总,当develop中的代码经过不断的测试,已经逐渐趋于稳定了,接近产品目标了。这时候,我们就可以把develop分支合并到master分支中,发布一个新版本。
  
  feature:功能性分支,是用于开发项目的功能的分支,是开发者主要战斗阵地。开发者在本地仓库从develop分支分出功能分支,在该分支上进行功能的开发,开发完成以后再合并到develop分支上,这时候功能性分支已经完成任务,可以删除。功能性分支的命名一般为feature-*,*为需要开发的功能的名称。
  release:预发布分支,当产品即将发布的时候,要进行最后的调整和测试,这时候就可以分出一个预发布分支,进行最后的bug fix。测试完全以后,发布新版本,就可以把预发布分支删除。预发布分支一般命名为release-*。
  hotfix:修复bug分支,当产品已经发布了,突然出现了重大的bug。这时候就要新建一个hotfix分支,继续紧急的bug修复工作,当bug修复完以后,把该分支合并到master和develop以后,就可以把该分支删除。修复bug分支命名一般为hotfix-*。
  示范:举一个例子,A正在做一个团队项目,已经把源仓库fork了,并且clone到了本地。现在要开发网站的某个功能。A在本地仓库中可以这样做:

  •   切换到develop分支 :>>> git checkout develop
  •   分出一个功能性分支: >>> git checkout -b feature-discuss
  •   在功能性分支上进行开发工作,多次commit,测试以后...
  •   把做好的功能合并到develop中:
      >>> git checkout develop    # 回到develop分支
      >>> git merge--no-ff feature-discuss# 把做好的功能合并到develop中
      >>> git branch -d feature-discuss    # 删除功能性分支
      >>> git push origin develop    # 把develop提交到自己的远程仓库中
  3. 工作流(workflow)
  1) 源仓库的构建,创建一个项目,初始化了两个永久性分支master和develop.
  2) 开发者fork源仓库
  3) 把自己开发者仓库clone到本地,命令:git clone
  4) 构建功能分支进行开发,完成后合并到自己的develop分支。
  进入仓库中,按照前面说所的构建功能分支的步骤,构建功能分支进行开发、合并,假设我现在要开发一个“讨论”功能:
  >>> git checkout develop    # 切换到`develop`分支
  >>> git checkout -b feature-discuss    # 分出一个功能性分支
  >> touch discuss.js    # 假装discuss.js就是我们要开发的功能
  >> git add .
  >> git commit -m 'finish discuss feature'# 提交更改
  >>> git checkout develop    # 回到develop分支
  >>> git merge--no-ff feature-discuss# 把做好的功能合并到develop中
  >>> git branch -d feature-discuss    # 删除功能性分支
  >>> git push origin develop    # 把develop提交到自己的远程仓库中
  5) 向管理员提交pull request。经过测试以后,觉得没问题,就可以请求管理员把自己仓库的develop分支合并到源仓库的develop分支中,这就是传说中的pull request。
  6) 管理员测试、合并
  1) 对代码进行review,github提供非常强大的代码review功能
  2) 在本地测试新建一个测试分支,测试pull request的代码
   >> git checkout develop    # 进入本地的develop分支
  >> git checkout -b livoras-develop
  # 从develop分支中分出一个叫livoras-develop的测试分支测试pull request代码
  >> git pull https://github.com/livoras/git-demo.git develop
  # 把pull request的代码pull到测试分支中,进行测试
  3) 判断是否同意合并到源仓库的develop中,如果经过测试没问题,可以把我的代码合并到源仓库的develop中:
  >> git checkout develop
  >> git merge--no-ff livoras-develop
  >> git push origin develop

运维网声明 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-435639-1-1.html 上篇帖子: Ubuntu12.04 GIT安装和使用 下篇帖子: ***Git 常用命令速查表(图文+表格)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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