首页 > 其他分享 >使用git和gitlab进行协同开发流程

使用git和gitlab进行协同开发流程

时间:2023-01-29 10:32:33浏览次数:31  
标签:git develop 仓库 gitlab 协同 master 开发者 分支

一、基本概念

1.仓库(Repository)

①源仓库(线上版本库)

在项目的开始,项目的发起者构建起一个项目的最原始的仓库,称为​​origin。​

源仓库的有两个作用:

1.汇总参与该项目的各个开发者的代码

2.存放趋于稳定和可发布的代码 

源仓库应该是受保护的,开发者不应该直接对其进行开发工作。只有项目管理者能对其进行较高权限的操作。

②开发者仓库(本地仓库)

任何开发者都不会对源仓库进行直接的操作,源仓库建立以后,每个开发者需要做的事情就是把源仓库的“复制”一份,作为自己日常开发的仓库。这个复制是gitlab上面的​​fork​​。

每个开发者所fork的仓库是完全独立的,互不干扰,甚至与源仓库都无关。每个开发者仓库相当于一个源仓库实体的影像,开发者在这个影像中进行编码,提交到自己的仓库中,这样就可以轻易地实现团队成员之间的并行开发工作。而开发工作完成以后,开发者可以向源仓库

发​​送pull request,​​请求管理员把自己的代码合并到源仓库中,这样就实现了分布式开发工作和集中式的管理

2.分支(Branch)

①master branch:主分支

master主分支从项目一开始便存在,它用于存放经过测试,已经完全稳定代码;在项目开发以后的任何时刻当中,​​master​​​存放的代码应该是可作为产品供用户使用的代码。所以,应该随时保持​​master​​​仓库代码的清洁和稳定,确保入库之前是通过完全测试和代​​码reivew​

​的​​​。​​master​​​分支是所有分支中最不活跃的,大概每个月或每两个月更新一次,每一次​​master​​​​更​​​新的时候都应该用​​git​​​打上​​tag​​,来说明产品有新版本发布。

②develop branch:开发分支

develop开发分支,一开始从​​master​​​分支中分离出来,用于开发者存放基本稳定代码。每个开发者的仓库相当于源仓库的一个镜像,每个开发者自己的仓库上也有​​master​​​和​​develop​​​。开发者把功能做好以后,是存放到自己的​​develop​​中,当测试完以后,可以向管理者

发起一个​​pull request​​​,请求把自己仓库的​​develop​​​分支合并到源仓库的​​develop​​​中。所有开发者开发好的功能会在源仓库的​​develop​​​分支中进行汇总,当​​develop​​​中的代码经过不断的测试,已经逐渐趋于稳定了,接近产品目标了。这时候,就可以把​​develop​​分支合并

到​​master​​分支中,发布一个新版本。

注:任何人不应该向​​master​​​直接进行无意义的合并、提交操作。正常情况下,​​master​​​只应该接受​​develop​​​的合并,也就是说,​​master​​​所有代码更新应该源于合并​​develop​​的代码。

③feature branch:功能分支

feature功能性分支,是用于开发项目的功能的分支,是开发者主要战斗阵地。开发者在本地仓库从​​develop​​​分支分出功能分支,在该分支上进行功能的开发,开发完成以后再合并到​​develop​​分支上,这时候功能性分支已经完成任务,可以删除。功能性分支的命名一般

为​​feature-*​​​​,*​​为需要开发的功能的名称。

二、如何操作(仅做举例说明用)

Step 1:源仓库的构建

这一步通常由项目发起人(项目管理员)来操作,源仓库为op/Chanj_Asset_Management,并初始化两个分支master和develop.

Step 2:开发者fork源仓库

源仓库建立以后,每个开发就可以去复制一份源仓库到自己的gitlab账号中,然后作为自己开发所用的仓库。假设我是一个项目中的开发者,我就到op/Chanj_Asset_Managemen项目主页上去fork.

Step 3:把自己开发者仓库clone到本地

>>> git clone http://gitlab.rd.chanj.com/op/Chanj_Asset_Management.git

Step 4:构建功能分支进行开发

假设现在要开发一个“讨论”功能:

>>> git checkout develop
>>> git checkout -b feature-discuss
>>> touch discuss.py
>>> git 
.
>>> git commit -m
>>> git checkout develop
>>> git
>>> git branch -d feature-discuss
>>> git push origin develop

此时,上自己gitlab的项目主页中​​develop​​​分支中查看,已经有​​discuss.py​​这个文件了:

Step 5:向管理员提交pull request

在完成了“讨论”功能(当然,也可能对自己的​​develop​​​进行了多次合并,完成了多个功能),经过测试以后,觉得没问题,就可以请求管理员把自己仓库的​​develop​​​分支合并到源仓库的​​develop​​分支中。

Step 6 管理员测试、合并

管理员登陆​​gitlab​​​,看到了开发者对源仓库发起的​​pull request​​​​。​

管理员需要做的事情就是:

1.开发者的代码进行review​​

2.在他的本地测试新建一个测试分支,测试开发者的代码:

>>> git checkout develop
>>> git checkout -b manager-develop
>>> git pull
http://gitlab.rd.chanj.com/op/Chanj_Asset_Management.git develop
# 把开发者的代码pull到测试分支中,进行测试

  判断是否同意合并到源仓库的develop,如果经过测试没问题,可以把开发者的代码合并到源仓库的​​develop​​中:

>>> git checkout develop
>>> git
>>> git push origin develop

注:管理员一直在操作的仓库是源仓库。

以上,就是一个​​git​​​和​​gitlab​​协同工作流的基本步骤。

标签:git,develop,仓库,gitlab,协同,master,开发者,分支
From: https://blog.51cto.com/muzinan110/6025457

相关文章

  • 查看git的用户名和密码
    转载自:https://www.cnblogs.com/xihailong/p/13354628.html一、查看查看用户名:gitconfiguser.name查看密码:gitconfiguser.password查看邮箱:gitconfiguser.email查......
  • netrw auto expand all node when using git difftool vimdiff compare two directoie
    匹配结点\v^(.([\.])@!)+\/$匹配节点,并展开:golobal/\v^(.([\.])@!)+\/$/exe"normal\<CR>"不过这里有个问题,展开过一次的节点,下次执行还会再展开一次,导致又关闭所......
  • 什么是“云计算”、“云边协同”
    “云计算”的概念由Google在2006年首次提出,随着IT、CT技术的不断发展和融合,云计算开始快速发展并广泛被接受,但是关于边缘计算、云边端、云边协同的含义及相关联系是什么呢?......
  • 02pycharm 如何添加代码上传到gitlab
    1.首先正确安装好python,pycharm工具(这边不做介绍) 2.下载git的windows客户端官网:https://git-scm.com/download/win  根据自己的系统选择合适的版本,下载安装......
  • 如何解决github下载很慢的问题?(已经解决)
    目的是为了解决GitHub致命的下载速度慢的问题方法通过码云来导入github,通过码云下载1.在github上面找到自己想要的项目这一步略过2.复制github项目上面的网页链......
  • GitHub2021年度报告:中国开发者数量全球第2,最受欢迎的语言?
    临近年底,各大平台年终报告频频发布。作为程序员,应该关注些什么呢?近日,全球最大开发者社区GitHub重磅发布了《2021年度Octoverse报告》,本报告首次结合了来自GitHub上,超过40......
  • Git使用笔记
    重新复习整理Git的使用说明,以及在实际工作中用到的一些,以及不常用的一些命令。笔者工作中,更多的时候是用IDEA的可视化快捷命令进行git管理。本文内容以及示意图主要参考Gi......
  • git常用命令
    1.开始新项目步骤如下:1.克隆远程仓库到本地仓库(首先建远程仓库,再克隆到本地仓库。注意这个只需要cd到你要的文件夹下,执行下面的命令就直接创建了本地仓库并关联了远程......
  • 解决Git下载速度慢的问题
    从Git官网上下载速度是非常慢的,所以推荐使用国内镜像地址(https://registry.npmmirror.com/binary.html?path=git-for-windows/v2.39.1.windows.1/)然后安装的时候直接默认......
  • git升级编译安装
    一、删除旧版本git方法一、yumremovegit-y(centos环境)apt-getremovegit-y(Ubuntu环境) 方法二、whichgit [root@park2-0007~]#which-agit/usr......