【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 分⽀帮忙继续开发,要做的操作如下:
- pull拉取远程仓库的feature-2分支到开发者1本地服务器上
- 建立联系
- 开发然后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远程仓库的内容,再继续开发。
- 建立远程feature-2分支和本地feature-2分支的联系
- 拉取远程仓库feature-2的内容
- 继续开发☞完成开发
- push推送至远程仓库(已经建立本地和远程的联系☞直接短命令push直接即可)(这里的短命令push就是推送分支底下的内容)
4.将内容合并进master分支
- function1和function2二者功能都完成了开发操作,现在需要都merge都master分支上去
- 解决方案:提交PR申请单
- 开发人员:PR☞申请单☞审查员:审核(老板、项目经理、技术经理)☞merge
- 存在两种情况
【1】开发分支feature直接和主分支master最新一次提交版本merge合并。(没有合并冲突)----演示feature-2
开发分支feature直接和主分支master最新一次提交版本merge合并存存冲突。--------演示feature-1
开发分支feature直接和主分支master最新一次提交版本merge合并存存冲突。
- 若master合并feature,存在冲突,则在master上去解决的。(可能出现更大bug问题
- 若feature合并master分支,存在冲突,在feature上解决的。再让master合并feature
- 注意:本地merge合并一定要pull拉取远程仓库最新的一次提交的版本的master分支
【2】本地☞远程
- 本地服务器操作:在本地仓库切换至feature-1 mereg合并 本地master分支,存在冲突,手动解决冲突,三板斧提交并且推送push。
- 远程服务器操作:在远程仓库master主分支 merge合并feature-1分支
【3】或者全在本地——前面博文演示过
- 在本地仓库切换至feature-1 mereg合并 本地master分支,存在冲突,手动解决冲突,三板斧提交
- 切换至本地master分支合并
- 最后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.总结模式
总结:
- 每个开发者都私有一个分支去开发各自的功能。(同一文件/不同文件)
- 开发完成之后(三板斧)push,基本不会出现冲突。
- 会出现小插曲(同事生病等)。
- 完成之后需要将开发分支部分合并到master。三个方案☞建议选择:远程和本地混合。
相关文章:

【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到远程仓库…...
Lua 复数计算器
Lua复数计算器 主要包括复数的加减乘除操作,以及打印 编写复数类 -- ***** 元类 ***** Complex {real 0, imag 0}-- 构造函数 function Complex:new(real, imag)local o o or {}o.real real or 0o.imag imag or 0setmetatable(o, self)self.__index selfr…...
深入MySQL中的IF和IFNULL函数
在数据库查询中,我们经常需要根据条件来决定数据的显示方式。MySQL提供了多种内置函数来帮助我们实现这种条件逻辑,其中IF和IFNULL是两个非常有用的函数。在这篇博客中,我们将深入探讨这两个函数的用法和它们在实际查询中的应用。 IF函数 I…...

AI多模态实战教程:面壁智能MiniCPM-V多模态大模型问答交互、llama.cpp模型量化和推理
一、项目简介 MiniCPM-V 系列是专为视觉-语⾔理解设计的多模态⼤型语⾔模型(MLLMs),提供⾼质量的⽂本输出,已发布4个版本。 1.1 主要模型及特性 (1)MiniCPM-Llama3-V 2.5: 参数规模: 8B性能…...

Docker 搭建Elasticsearch详细步骤
本章教程使用Docker搭建Elasticsearch环境。 一、拉取镜像 docker pull docker.elastic.co/elasticsearch/elasticsearch:8.8.2二、运行容器 docker run -d --name elasticsearch -p 9200:9200 -p 9300:9300 -e "discovery.type=single-n...
mysql中提供的函数
文章目录 1.聚合函数2.字符串函数3.数值函数4.日期函数5.流程函数 MySQL 是一个功能强大的关系型数据库管理系统,其中包含了丰富的内置函数,用于处理各种数据操作和查询。这些函数可以分为多种类型,包括字符串函数、数值函数、日期和时间函数…...

加速下载,揭秘Internet Download Manager2024下载器的威力!
1. Internet Download Manager(IDM)是一款广受欢迎的下载管理软件,以其强大的下载加速功能和用户友好的界面著称。 IDM马丁正版下载如下: https://wm.makeding.com/iclk/?zoneid34275 idm最新绿色版一键安装包链接:抓紧保存以…...
oracle 宽表设计
Oracle宽表设计主要涉及到数据库表或视图中字段(列)数量较多的情况。在Oracle 23c及以后的版本中,数据库表或视图中允许的最大列数已增加到4096,这为宽表设计提供了更大的灵活性。以下是对Oracle宽表设计的详细分析: …...

winrar安装好后,鼠标右键没有弹出解压的选项
本来安装挺好的,可以正常使用,有天我把winrar相关的文件挪了个位置,就不能正常使用了。 然后我去应用里面找,找到应用标识了,但是找不到对应的文件夹(因为我挪到另外一个文件夹里了)。 于是我找…...

数字图像处理笔记(一)---- 图像数字化与显示
系列文章目录 数字图像处理学习笔记(一)---- 图像数字化与显示 数字图像处理笔记(二)---- 像素加图像统计特征 数字图像处理笔记(三) ---- 傅里叶变换的基本原理 文章目录 系列文章目录前言一、数字图像处理二、图像数…...

Unity UGUI 之 事件接口
本文仅作学习笔记与交流,不作任何商业用途 本文包括但不限于unity官方手册,唐老狮,麦扣教程知识,引用会标记,如有不足还请斧正 本文在发布时间选用unity 2022.3.8稳定版本,请注意分别 1.什么是事件接口&…...

Hadoop、HDFS、MapReduce 大数据解决方案
本心、输入输出、结果 文章目录 Hadoop、HDFS、MapReduce 大数据解决方案前言HadoopHadoop 主要组件的Web UI端口和一些基本信息MapReduceMapReduce的核心思想MapReduce的工作流程MapReduce的优缺点Hadoop、HDFS、MapReduce 大数据解决方案 编辑 | 简简单单 Online zuozuo 地址…...
Dubbo SPI 之负载均衡
1. 背景介绍 在分布式系统中,负载均衡是一项核心技术,旨在将请求合理地分配到多个服务实例上,以提高系统的性能和可靠性。Dubbo 作为一个高性能的 Java RPC 框架,提供了多种负载均衡策略来满足不同的业务需求。本文将深入探讨 Du…...

规范:前后端接口规范
1、前言 随着互联网的高速发展,前端页面的展示、交互体验越来越灵活、炫丽,响应体验也要求越来越高,后端服务的高并发、高可用、高性能、高扩展等特性的要求也愈加苛刻,从而导致前后端研发各自专注于自己擅长的领域深耕细作。 然…...
Python --NumPy库基础方法(2)
NumPy Numpy(Numerical Python) 是科学计算基础库,提供大量科学计算相关功能,比如数据统计,随机数生成等。其提供最核心类型为多维数组类型(ndarray),支持大量的维度数组与矩阵运算,Numpy支持向…...
音视频入门基础:H.264专题(15)——FFmpeg源码中通过SPS属性获取视频帧率的实现
音视频入门基础:H.264专题系列文章: 音视频入门基础:H.264专题(1)——H.264官方文档下载 音视频入门基础:H.264专题(2)——使用FFmpeg命令生成H.264裸流文件 音视频入门基础&…...

【C++高阶】哈希之美:探索位图与布隆过滤器的应用之旅
📝个人主页🌹:Eternity._ ⏩收录专栏⏪:C “ 登神长阶 ” 🤡往期回顾🤡:模拟实现unordered 的奥秘 🌹🌹期待您的关注 🌹🌹 ❀哈希应用 Ǵ…...

文件包涵条件竞争(ctfshow82)
Web82 利用 session.upload_progress 包含文件漏洞 <!DOCTYPE html> <html> <body> <form action"https://09558c1b-9569-4abd-bf78-86c4a6cb6608.challenge.ctf.show//" method"POST" enctype"multipart/form-data"> …...

通信原理-思科实验三:无线局域网实验
实验三 无线局域网实验 一:无线局域网基础服务集 实验步骤: 进入物理工作区,导航选择 城市家园; 选择设备 AP0,并分别选择Laptop0、Laptop1放在APO范围外区域 修改笔记本的网卡,从以太网卡切换到无线网卡WPC300N 切…...
*算法训练(leetcode)第三十一天 | 1049. 最后一块石头的重量 II、494. 目标和、474. 一和零
刷题记录 *1049. 最后一块石头的重量 II*494. 目标和474. 一和零 *1049. 最后一块石头的重量 II leetcode题目地址 本题与分割等和子集类似,要达到碰撞最后的石头重量最小,则尽可能把石头等分为两堆。 时间复杂度: O ( m ∗ n ) O(m * n)…...

wordpress后台更新后 前端没变化的解决方法
使用siteground主机的wordpress网站,会出现更新了网站内容和修改了php模板文件、js文件、css文件、图片文件后,网站没有变化的情况。 不熟悉siteground主机的新手,遇到这个问题,就很抓狂,明明是哪都没操作错误&#x…...
Ubuntu系统下交叉编译openssl
一、参考资料 OpenSSL&&libcurl库的交叉编译 - hesetone - 博客园 二、准备工作 1. 编译环境 宿主机:Ubuntu 20.04.6 LTSHost:ARM32位交叉编译器:arm-linux-gnueabihf-gcc-11.1.0 2. 设置交叉编译工具链 在交叉编译之前&#x…...

51c自动驾驶~合集58
我自己的原文哦~ https://blog.51cto.com/whaosoft/13967107 #CCA-Attention 全局池化局部保留,CCA-Attention为LLM长文本建模带来突破性进展 琶洲实验室、华南理工大学联合推出关键上下文感知注意力机制(CCA-Attention),…...
系统设计 --- MongoDB亿级数据查询优化策略
系统设计 --- MongoDB亿级数据查询分表策略 背景Solution --- 分表 背景 使用audit log实现Audi Trail功能 Audit Trail范围: 六个月数据量: 每秒5-7条audi log,共计7千万 – 1亿条数据需要实现全文检索按照时间倒序因为license问题,不能使用ELK只能使用…...

uniapp微信小程序视频实时流+pc端预览方案
方案类型技术实现是否免费优点缺点适用场景延迟范围开发复杂度WebSocket图片帧定时拍照Base64传输✅ 完全免费无需服务器 纯前端实现高延迟高流量 帧率极低个人demo测试 超低频监控500ms-2s⭐⭐RTMP推流TRTC/即构SDK推流❌ 付费方案 (部分有免费额度&#x…...
工业自动化时代的精准装配革新:迁移科技3D视觉系统如何重塑机器人定位装配
AI3D视觉的工业赋能者 迁移科技成立于2017年,作为行业领先的3D工业相机及视觉系统供应商,累计完成数亿元融资。其核心技术覆盖硬件设计、算法优化及软件集成,通过稳定、易用、高回报的AI3D视觉系统,为汽车、新能源、金属制造等行…...
精益数据分析(97/126):邮件营销与用户参与度的关键指标优化指南
精益数据分析(97/126):邮件营销与用户参与度的关键指标优化指南 在数字化营销时代,邮件列表效度、用户参与度和网站性能等指标往往决定着创业公司的增长成败。今天,我们将深入解析邮件打开率、网站可用性、页面参与时…...

sipsak:SIP瑞士军刀!全参数详细教程!Kali Linux教程!
简介 sipsak 是一个面向会话初始协议 (SIP) 应用程序开发人员和管理员的小型命令行工具。它可以用于对 SIP 应用程序和设备进行一些简单的测试。 sipsak 是一款 SIP 压力和诊断实用程序。它通过 sip-uri 向服务器发送 SIP 请求,并检查收到的响应。它以以下模式之一…...
【Go语言基础【13】】函数、闭包、方法
文章目录 零、概述一、函数基础1、函数基础概念2、参数传递机制3、返回值特性3.1. 多返回值3.2. 命名返回值3.3. 错误处理 二、函数类型与高阶函数1. 函数类型定义2. 高阶函数(函数作为参数、返回值) 三、匿名函数与闭包1. 匿名函数(Lambda函…...

三分算法与DeepSeek辅助证明是单峰函数
前置 单峰函数有唯一的最大值,最大值左侧的数值严格单调递增,最大值右侧的数值严格单调递减。 单谷函数有唯一的最小值,最小值左侧的数值严格单调递减,最小值右侧的数值严格单调递增。 三分的本质 三分和二分一样都是通过不断缩…...