【Git多人协作开发】不同的分支下的多人协作开发模式

目录

0.前言背景

1.开发者1☞完成准备工作&协作开发

1.1查看分支情况

1.2创建本地分支feature-1

1.3三板斧

1.4push推本地分支feature-1到远程仓库

2.开发者2☞完成准备工作&协作开发

2.1创建本地分支feature-2

2.2三板斧

2.2push推送本地feature-2到远程仓库

3.出现同一分支下多人协作开发问题

3.1查看分支情况

3.2拉取远程feature-2分支

3.3创建本地feature-2分支并且和远程建立联系

3.4三板斧

3.5回到不同分支多人协作开发问题 

4.将内容合并进master分支

4.1无冲突演示feature2

4.2存在冲突演示feature1

4.2.1拉取pull最新master版本

4.2.2feature合并master

4.2.3push推送至远程仓库

4.2.4远程仓库提交PR:master合并feature1

5.删除无用分支feature-1或者feature-2

6.总结模式


0.前言背景

不同分支去实现不同的function

  • 可以是不同开发者实现不同的function使用不同的分支。

  • 可以是不同开发者实现不同的function使用不同的分支。

  • 可以是同一份文件,也可以是不同文件。

  • ❗重点是:不同分支针对是不同的function


  • 目标:远程master分支下新增function1和function2文件。
  • 实现:由开发者1新增function1,由开发者2新增function2。
  • 条件:在不同分支下协作完成,各自让某一个功能私有某一个分支。
  • 重点:在公司里面,都是一个功能function 对应一个分支这样子来玩的。push不会出现冲突问题。
  • 同一分支下多人协作开发场景:push会出现冲突问题。

1.开发者1☞完成准备工作&协作开发

1.1查看分支情况

git branch -a 

查看分支情况(远程分支/本地分支,远程分支是远程分支,本地分支是本地分支)

1.2创建本地分支feature-1

  • 无论是本地创建还是远程创建,都需要基于master的最新一次提交的版本。
  • 在本地创建的feature的时候必须确保基于本地master分支创建的feature-1分支中的master分支相较于远程分支master分支是最新一次提交记录的版本。
  • 好习惯:git checkout master     git pull
  • git checkout -b feature-1:创建本地分支feature-1

1.3三板斧

vim function1

git add function1

git commit -m "add func1"

git push origin feature-1 

1.4push推本地分支feature-1到远程仓库

git push origin feature-1 

注意:在推送本地分支到远程仓库时(远程仓库创建分支的同时),与本地仓库建立联系了

 

2.开发者2☞完成准备工作&协作开发

2.1创建本地分支feature-2

  • 无论是本地创建还是远程创建,都需要基于master的最新一次提交的版本。
  • 在本地创建的feature的时候必须确保基于本地master分支创建的feature-1分支中的master分支相较于远程分支master分支是最新一次提交记录的版本。
  • 好习惯:git checkout master     git pull
  • git checkout -b feature-2:创建本地分支feature-2

【Windows下不用命令直接操作也可】

2.2三板斧

git add function2

git commit -m "add func2"

git push origin feature-2

 

2.2push推送本地feature-2到远程仓库

git push origin feature-2

  • 注意:在推送本地分支到远程仓库时(远程仓库创建分支的同时),与本地仓库建立联系了
  • 发现不同开发者正在协作开发的过程中,并没有解决冲突。是同一份文件的功能开发push推送也不会有冲突
  • 因为是在不同的分支下开发,各自私有的分支,所以不会有冲突。

 

3.出现同一分支下多人协作开发问题

正常情况下,你俩就可以在⾃⼰的分⽀上进⾏专业的开发了!
但天有不测⻛云,你的⼩伙伴突然⽣病了,但需求还没开发完,需要你帮他继续开发,于是他便把feature-2 分⽀名告诉你了。这时你就需要在⾃⼰的机器上切换到 feature-2 分⽀帮忙继续开发,要做的操作如下:

  1. pull拉取远程仓库的feature-2分支到开发者1本地服务器上
  2. 建立联系
  3. 开发然后push推送

3.1查看分支情况

git branch -a 

查看分支情况(远程分支/本地分支,远程分支是远程分支,本地分支是本地分支)

3.2拉取远程feature-2分支

git pull :这里短pull是拉取远程仓库的内容。(而非分支下的内容

3.3创建本地feature-2分支并且和远程建立联系

git checkout -b dev origin/dev:在创建dev分支的时,切换到了本地dev分支下,同时将本地dev分支和远程的dev分支建立了一个连接。

3.4三板斧

vim function2

git add function2

git commit -m "add func2"

git push origin feature-2

3.5回到不同分支多人协作开发问题 

此刻开发者1开发完function-2的1/3内容了,他的亲亲同事病好了。他准备在他的电脑上继续开发。此刻同事电脑上,并没有开发者1开发的内容。所以他需要先拉取pull远程仓库的内容,再继续开发。

  1. 建立远程feature-2分支和本地feature-2分支的联系
  2. 拉取远程仓库feature-2的内容
  3. 继续开发☞完成开发
  4. push推送至远程仓库(已经建立本地和远程的联系☞直接短命令push直接即可)(这里的短命令push就是推送分支底下的内容

 

4.将内容合并进master分支

  • function1和function2二者功能都完成了开发操作,现在需要都merge都master分支上去
  • 解决方案:提交PR申请单
  • 开发人员:PR☞申请单☞审查员:审核(老板、项目经理、技术经理)☞merge
  • 存在两种情况
  1. 【1】开发分支feature直接和主分支master最新一次提交版本merge合并。(没有合并冲突)----演示feature-2

  2. 开发分支feature直接和主分支master最新一次提交版本merge合并存存冲突。--------演示feature-1


开发分支feature直接和主分支master最新一次提交版本merge合并存存冲突。   

  • 若master合并feature,存在冲突,则在master上去解决的。(可能出现更大bug问题
  • 若feature合并master分支,存在冲突,在feature上解决的。再让master合并feature
  • 注意:本地merge合并一定要pull拉取远程仓库最新的一次提交的版本的master分支

【2】本地☞远程

  1. 本地服务器操作:在本地仓库切换至feature-1 mereg合并 本地master分支,存在冲突,手动解决冲突,三板斧提交并且推送push。
  2. 远程服务器操作:在远程仓库master主分支 merge合并feature-1分支  

【3】或者全在本地——前面博文演示过

  1. 在本地仓库切换至feature-1 mereg合并 本地master分支,存在冲突,手动解决冲突,三板斧提交
  2. 切换至本地master分支合并
  3. 最后push推送至远程仓库

4.1无冲突演示feature2

4.2存在冲突演示feature1

4.2.1拉取pull最新master版本

git checkout master

git pull:这里的短命令push就是推送分支底下的内容

4.2.2feature合并master

git checkout feature-1

git merge master

下面页面表示merge的两个分支,没有任何的冲突。Ctrl+x自动退出了

4.2.3push推送至远程仓库

 git push origin feature-1 

注意:在推送本地分支到远程仓库时(远程仓库创建分支的同时),与本地仓库建立联系了

4.2.4远程仓库提交PR:master合并feature1

5.删除无用分支feature-1或者feature-2

6.总结模式

总结:

  1. 每个开发者都私有一个分支去开发各自的功能。(同一文件/不同文件)
  2. 开发完成之后(三板斧)push,基本不会出现冲突。
  3. 会出现小插曲(同事生病等)。
  4. 完成之后需要将开发分支部分合并到master。三个方案☞建议选择:远程和本地混合。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/48467.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

FineBI连接MySQL5.7

一、在FineBI系统管理中,点击【新建数据库连接】 选择MySQL数据库 配置数据库连接,如下,其中数据库名称就是需要连接的目标数据库

【通信协议-RTCM】MSM语句(2) - RINEXMSM7语句总结(重要!自动化开发计算卫星状态常用)

注释: 在工作中主要负责的是RTCM-MSM7语句相关开发工作,所以主要介绍的就是MSM7语句相关内容 1. 相位校准参考信号 2. MSM1、MSM2、MSM3、MSM4、MSM5、MSM6和MSM7的消息头内容 DATA FIELDDF NUMBERDATA TYPENO. OF BITSNOTES Message Number - 消息编…

DML数据操作语句和基本的DQL语句

一、MySQL对数据的增删改查 1.DML语句 1.1 增加数据(INSERT) insert into 表名 (字段名,字段名,...字段名) values/value (值,值,...值) 1.1.1 新增数据的具体实现 (1)全字段的插入 方式一: insert into student (sid,sname,birthday,ssex,…

【2024最新华为OD-C/D卷试题汇总】[支持在线评测] 开源项目热度排行榜(100分) - 三语言AC题解(Python/Java/Cpp)

🍭 大家好这里是清隆Coding ,一枚热爱算法的程序员 ✨ 本系列打算持续跟新华为OD-C/D卷的三语言AC题解 👏 感谢大家的订阅➕ 和 喜欢💗 🍿 最新华为OD机试D卷目录,全、新、准,题目覆盖率达 95% 以上,支持题目在线评测,专栏文章质量平均 93 分 最新华为OD机试目录…

Linux网络-配置IP

作者介绍:简历上没有一个精通的运维工程师。希望大家多多关注作者,下面的思维导图也是预计更新的内容和当前进度(不定时更新)。 本来IP配置应该放在Linux安装完成的就要配置的,但是由于那个时候对Linux不怎么熟悉,所以单独列了一个…

JVM系列(一) -浅谈虚拟机的成长史

一、摘要 众所周知,Java 经过多年的发展,已经从一门单纯的计算机编程语言,发展成了一套成熟的软件解决方案。从互联网到企业平台,Java 是目前使用最广泛的编程语言。 以下这段内容是来自 Java 的官方介绍! 从笔记本电…

图片变更检测

20240723 By wdhuag 目录 前言: 参考: 文件监控: 图片占用问题: 源码: 前言: 由于第三方图像处理软件不能回传图片(正常都能做,这里只是不想做),只能在…

Postman接口测试工具的使用

一、postman简介 Postman是一款功能强大的网页调试与发送网页HTTP请求的Chrome插件。作用:常用于进行接口测试。不需要安装。 特征:简单,实用,美观,大方。 二、Postman接口测试工具的使用 Postman不需要安…

MySQL的账户管理

目录 1 密码策略 1.1 查看数据库当前密码策略: 1.2 查看密码设置策略 1.3 密码强度检查等级解释(validate_password.policy) 2 新建登录账户 3 账户授权 3.1 赋权原则 3.2 常见的用户权限 3.3 查看权限 3.4 赋权语法 4 实例 4.1 示例1&#x…

python脚本制作循环执行命令行

python import subprocess import sysif __name____main__:ret 1while ret!0:ret subprocess.call(sys.argv[1:], textTrue)pack pip install pyinstaller pyinstaller --onefile loop.py 使用场景 使用上面生成的loop.exe调用cmd命令,执行失败了返回值&#xf…

项目实战二

Git 服务器 公共代码平台GitLab 配置gitlab 1.设置管理员帐号密码 2.让程序员传代码到20主机上需要配置: 创建用户 mark 1234.com 创建用户组devops 然后把mark 添加到devons 创建项目 http://192.168.88.20/devops/myproject.git 3.客户端操作&#x…

textblob文本处理、词性分析与情感分析

1 前言 textBlob 是一個简单易用的 NLP库,基于 NLTK 和 pattern库, 提供了文本处理和情感分析等功能。 安装 textblob0.18.0 nltk3.8.1测试环境:Python3.10.9 使用前,先运行下面代码先下载些文件 import nltk nltk.download…

C#医学影像管理系统源码 PACS系统源码带三维重建,全院级数字医学影像系统

C#医学影像管理系统源码 医学影像存储与传输系统源码 PACS系统源码带三维重建,三甲以下医院都能满足。 PACS系统模块组成 : 工作站: 分诊工作站、超声工作站、放射工作站、内镜工作站、病理工作站。 基本信息维护: 输入模板、输入…

Layer2区块链扩容方案(1)——总述

写在前面 这篇文章作为一个简单介绍,很多技术只是大致提及或者引用,之后会在详细学习后逐项解释。 补充知识 在了解扩容方案之前,我们最好了解一些相关的知识概念 EVM “EVM” 是“Ethereum Virtual Machine”(以太坊虚拟机&…

相机的内参与外参

目录 一、相机的内参二、相机的外参 一、相机的内参 如下图所示是相机的针孔模型示意图: 光心O所处平面是相机坐标系(O,P),像素平面所在坐标系为像素坐标系(O’,P’)。 焦距f:O到O’的距离 相机的内参表示的是相机坐标…

QT 信号槽机制

核心函数为 QMetaObject::Connection QObject::connect(const QObject *sender, const char *signal, const QObject *receiver, const char *method, Qt::ConnectionType type Qt::AutoConnection) 参数为 1.信号发生对象 2.信号发生对象的信号 3.槽对象 4.槽对象的槽函…

嵌入式linux系统中压力测试的方法

在Linux环境下,确保系统各项资源充分且稳定地运行对任何系统管理员来说都至关重要。特别是在生产环境中,理解如何对系统资源进行基准测试和压力测试可以帮助预防未来的问题,同时也能够优化现有系统的性能。 在本文中,我们将探讨如何使用命令行工具来对Linux系统的CPU、内存…

C语言 ——— 函数指针的定义 函数指针的使用

目录 何为函数指针 打印 函数名的地址 及 &函数名的地址 函数指针的代码(如何正确存储函数地址) 函数指针的使用 何为函数指针 类比: 整型指针 - 指向整型数据的指针,整型指针存放的是整型数据的地址 字符指针 - 指向字…

SQLynx数据库管理工具

背景:业主对网络安全要求比较高,不提供VPN等远程工具,也不能开放3306端口到互联网。那怎么样运维数据库就是个难题?找到了SQLynx这个可以网页访问的数据库管理工具,给大家分享一下。 1.介绍 SQLynx原名SQL Studio&…

平面五杆机构运动学仿真matlab simulink

1、内容简介 略 89-可以交流、咨询、答疑 2、内容说明 略 ] 以 MATLAB 程序设计语言为平台 , 以平面可调五杆机构为主要研究对象 , 给定机构的尺寸参数 , 列出所 要分析机构的闭环矢量方程 , 使用 MATLAB 软件中 SIMULINK 仿真工具 , 在 SIMULINK 模型窗口下建立数…