【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.rhkb.cn/news/383272.html

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

相关文章

黑马JavaWeb企业级开发(知识清单)01——前端介绍,HTML实现标题:排版

文章目录 前言一、认识web前端、HTML、CSS二、VS Code开发工具&#xff08;插件弃用问题&#xff09;三、HTML结构标签介绍1. 标签页标题< title >2. 图片标签< img >1) 常见属性2) src路径书写方式 3. 标题标签< h >4. 水平分页线标签< hr > 四、用Vs…

生成树协议配置与分析

前言&#xff1a;本博客仅作记录学习使用&#xff0c;部分图片出自网络&#xff0c;如有侵犯您的权益&#xff0c;请联系删除 一、相关知识 1、生成树协议简介 生成树协议&#xff08;STP&#xff09;是一种避免数据链路层逻辑环路的机制&#xff0c;它通过信息交互识别环路并…

ZLMRTCClient配置说明与用法(含示例)

webRTC播放视频 后面在项目中会用到通过推拉播放视频流的技术&#xff0c;所以最近预研了一下webRTC 首先需要引入封装好的webRTC客户端的js文件ZLMRTCClient.js 下面是地址需要的自行下载 http://my.zsyou.top/2024/ZLMRTCClient.js 配置说明 new ZLMRTCClient.Endpoint…

AI/机器学习(计算机视觉/NLP)方向面试复习2

1. 用pytorch写一个self-attention 继承pytorch.nn.Module的类 代码&#xff1a; import torch import torch.nn as nn import torch.nn.functional as Fclass SelfAttention(nn.Module):def __init__(self, embed_size): # (B,T,C)super(SelfAttention, self).__init__()sel…

如何优化 Selenium 和 BeautifulSoup 的集成以提高数据抓取的效率?

摘要 在互联网时代&#xff0c;数据的价值日益凸显。对于电商网站如京东&#xff0c;其商品信息、用户评价等数据对于市场分析、产品定位等具有重要意义。然而&#xff0c;由于这些网站通常使用 JavaScript 动态生成内容&#xff0c;传统的爬虫技术难以直接获取到完整数据。本…

手机空号过滤批量查询的意义及方法

手机空号过滤批量查询是现代营销和通信管理中常用的技术手段&#xff0c;旨在通过批量处理手机号码&#xff0c;筛选出活跃号码和空号等无效号码&#xff0c;以提高营销效率和减少不必要的通信成本。以下是关于手机空号过滤批量查询的详细解答&#xff1a; 一、手机空号过滤批…

逆向笔记-某贴

逆向环境搭建 雷电模拟器9LsposedMagisk DeltaMTNP管理器算法助手2.1.2 软件链接&#xff1a; https://llzai.lanzouv.com/iWgV125h6vwj 密码:a0zy 主要注释代码 捕获窗口&#xff0c;查看日志&#xff0c;定位代码 找到show的里面的alertdialog的相关行都注释掉就好了&am…

HTML5-canvas1

1、canvas&#xff1a;创建画布 <canvas id"canvas"></canvas>2、画一条直线 var canvasdocument.getElementById(cancas&#xff09;; canvas.width800; canvas.height800; var contextcanvas.getContext(2d); //获得2d绘图上下文环境 //画一条直线 c…

全新AI工具——PaintsUndo:一键自动还原图像绘画过程!

ControlNet 作者 Lvmin Zhang 又开始整活了&#xff01;这次发布的PaintsUndo 只需要上传一张图片&#xff0c; 就能够一键生成绘画过程&#xff01;快来了解学习&#xff01; 1、核心技术 PaintsUndo 是一项突破性的技术&#xff0c;旨在通过输入静态图像&#xff0c;自动生…

基于vue-grid-layout插件(vue版本)实现增删改查/拖拽自动排序等功能(已验证、可正常运行)

前端时间有个需求&#xff0c;需要对33&#xff08;不一定&#xff0c;也可能多行&#xff09;的卡片布局&#xff0c;进行拖拽&#xff0c;拖拽过程中自动排序&#xff0c;以下代码是基于vue2&#xff0c;可直接运行&#xff0c;报错可评论滴我 部分代码优化来自于GPT4o和Clau…

Live555源码阅读笔记:哈希表的实现

&#x1f601;博客主页&#x1f601;&#xff1a;&#x1f680;https://blog.csdn.net/wkd_007&#x1f680; &#x1f911;博客内容&#x1f911;&#xff1a;&#x1f36d;嵌入式开发、Linux、C语言、C、数据结构、音视频&#x1f36d; &#x1f923;本文内容&#x1f923;&a…

Air780EP模块 LuatOS开发-MQTT接入阿里云应用指南

简介 本文简单讲述了利用LuatOS-Air进行二次开发&#xff0c;采用一型一密、一机一密两种方式认证方式连接阿里云。整体结构如图 关联文档和使用工具&#xff1a;LuatOS库阿里云平台 准备工作 Air780EP_全IO开发板一套&#xff0c;包括天线SIM卡&#xff0c;USB线 PC电脑&…

【时时三省】unity test 测试框架 下载

目录 1&#xff0c;unity test 测试框架介绍 2&#xff0c;源码下载 3&#xff0c;目录架构 4&#xff0c;git for window 下载安装方法&#xff1a; 1&#xff0c;unity test 测试框架介绍 Unity是一个用于C语言的轻量级单元测试框架。它由Throw The Switch团队开发&#…

LINUX客户端client(socket、connect,write)实现客户端发送,服务器接收

SERVICE端见前一篇文章 5. 客户端连接函数 connect()&#xff08;与前面的bind一样&#xff09; int connect (int sockfd, struct sockaddr * serv_addr, int addrlen) 参数&#xff1a; sockfd: 通过 socket() 函数拿到的 fd addr:struct sockaddr 的结构体变量地址 addr…

深入指南:VitePress 如何自定义样式

&#x1f49d;&#x1f49d;&#x1f49d;欢迎莅临我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐:「stormsha的主页」…

二级医院LIS系统源码,医学检验系统,支持DB2,Oracle,MS SQLServer等主流数据库

系统概述&#xff1a; LIS系统即实验室信息管理系统。LIS系统能实现临床检验信息化&#xff0c;检验科信息管理自动化。其主要功能是将检验科的实验仪器传出的检验数据经数据分析后&#xff0c;自动生成打印报告&#xff0c;通过网络存储在数据库中&#xff0c;使医生能够通过医…

[Vulnhub] Acid-Reloaded SQLI+图片数据隐写提取+Pkexec权限提升+Overlayfs权限提升

信息收集 IP AddressOpening Ports192.168.101.158TCP:22,33447 $ nmap -p- 192.168.101.158 --min-rate 1000 -sC -sV Not shown: 65534 closed tcp ports (conn-refused) PORT STATE SERVICE VERSION 22/tcp open ssh OpenSSH 6.7p1 Ubuntu 5ubuntu1.3 (Ubuntu Lin…

C#开发的全屏图片切换效果应用 - 开源研究系列文章 - 个人小作品

这天无聊&#xff0c;想到上次开发的图片显示软件《 PhotoNet看图软件 》&#xff0c;然后想到开发一个全屏图片切换效果的应用&#xff0c;类似于屏幕保护程序&#xff0c;于是就写了此博文。这个应用比较简单&#xff0c;主要是全屏切换换图片效果的问题。 1、 项目目录&…

c++初阶知识——string类详解

目录 前言&#xff1a; 1.标准库中的string类 1.1 auto和范围for auto 范围for 1.2 string类常用接口说明 1.string类对象的常见构造 1.3 string类对象的访问及遍历操作 1.4. string类对象的修改操作 1.5 string类非成员函数 2.string类的模拟实现 2.1 经典的string…

【Git】上传代码命令至codeup云效管理平台

通过git命令上传本地代码库至阿里的codeup云效管理平台的代码管理模块&#xff0c;使用方便&#xff0c;且比github上传网络环境要求低&#xff0c;超大文件&#xff08;>100M&#xff09;的文件也可以批量上传&#xff0c;且上传速度喜人。 目录 &#x1f337;&#x1f33…