图解Git——分布式Git《Pro Git》

news2025/1/23 0:28:29

分布式工作流程

Centralized Workflow(集中式工作流)

  • 所有开发者都与同一个中央仓库同步代码,每个人通过拉取、提交来合作。
  • 如果两个开发者同时修改了相同的文件,后一个开发者必须在推送之前合并其他人的更改。

Integration-Manager Workflow(集成管理者工作流)

  • 每个开发者拥有自己仓库的写权限,主仓库由维护者管理。
  • 开发者通过 fork 主仓库,推送更改到自己的仓库后,向维护者请求合并。
  • 维护者拉取开发者的更改,进行测试和合并后,推送回主仓库。

Dictator and Lieutenants Workflow(主管与副主管工作流)

  • 适用于大型项目,尤其是多个维护者的项目。项目中的 Dictator 负责最终的合并,Lieutenants 负责各自模块。
  • 开发者在自己的分支上工作,提交到 Lieutenant 的分支,再由 Lieutenant 合并到主分支,最终由 Dictator 合并到中央仓库。

向一个项目做贡献

向一个项目贡献代码的过程涉及到几个关键的因素,其中每个因素都可能影响贡献的方式、流程以及最终效果。以下是一个稍微详细的描述,包括了如何贡献代码、涉及的困难以及如何有效管理提交。

1. 活跃贡献者的数量

项目的活跃贡献者数量直接影响代码贡献的难易程度。对于小型项目,活跃的贡献者可能只有几位,每天的提交次数不多。而对于大型开源项目,贡献者可能成千上万,提交的频率也非常高。随着贡献者增多,代码的合并和应用会面临更多挑战:

  • 问题:当多个贡献者提交改动时,代码可能会发生冲突。不同的开发者可能修改相同的文件或功能,导致合并时出现冲突或代码不兼容。
  • 解决方案:使用频繁的拉取最新代码(git pull解决合并冲突的技巧非常重要。合并冲突必须在本地解决,确保最终代码与其他人提交的代码兼容。

2. 项目使用的工作流程

项目的工作流程通常取决于项目的大小和复杂度。以下是常见的几种工作流:

  • 集中式工作流:所有贡献者都拥有对主分支(master)的写入权限,可以直接提交代码。这种工作流简单,适用于小团队或私有项目。
  • 分支工作流:每个开发者在自己的分支上工作,修改完成后通过**拉请求(pull request)合并请求(merge request)**向主分支提交代码。这是更常见的工作流,尤其是对于开源项目。
  • 维护者工作流:对于大型项目,维护者或核心开发人员负责审查和合并来自其他开发者的代码,外部贡献者需要通过提交拉请求来提供自己的改动。

影响:你需要明确自己所参与的项目采用哪种工作流程。如果是分支工作流,你可能需要在自己完成代码后,推送到自己的分支上,再通过拉请求的方式提交合并。

3. 提交权限

提交权限的管理是一个重要的因素,它决定了你如何将代码提交到项目中:

  • 有写权限:如果你有直接的写权限,可以直接提交代码到主分支或者其他分支。
  • 没有写权限:如果没有写权限,通常需要通过提交拉请求或合并请求的方式贡献代码。维护者将审核你的代码,并决定是否合并。

影响:如果没有直接的写权限,你需要了解项目是否有贡献指南,遵循规定的流程来提交代码。

4. 如何确保代码合并成功

代码合并的过程中,通常会涉及以下步骤:

  • 拉取最新代码:确保你的本地分支与远程仓库的代码是同步的。
git pull origin master

如果有人提交了新的改动,你需要合并他们的代码到自己的分支。

  • 解决冲突:在合并时,如果出现冲突,Git 会提示你冲突的文件。你需要手动解决这些冲突。
git mergetool

使用适当的工具来解决冲突。

  • 推送代码:将你的代码提交到远程仓库。对于有写权限的用户,可以直接推送到主分支;对于没有写权限的用户,推送到自己的分支并发起拉请求。
git push origin my-feature-branch

5. 提交准则和提交信息规范

提交信息是贡献中非常重要的一部分,合理的提交信息有助于项目维护者理解你的改动,并在后期进行回溯时找到问题。以下是一些常见的提交准则:

  • 避免空白错误:在提交代码前,运行 git diff --check 检查代码是否有空格或其他格式错误。
  • 保持提交逻辑清晰:每个提交应该是一个逻辑上独立的变更集。避免将多个不相关的功能或修复合并成一个提交。你可以通过 git add --patch 来分拆提交,确保每次提交都是相关的、功能明确的。
  • 提交信息的格式:通常,提交信息应包含以下部分:
    • 简洁的摘要:不超过 50 个字符,简要描述改动内容。
    • 详细描述:如果需要,可以提供更多的背景信息,包括为什么要进行这个改动,改动的动机以及如何影响代码的行为。

示例:

Add user authentication logic

Implement login and registration features with validation and error handling.
This change introduces a new User model and modifies the authentication flow.

6. 常见的合并和冲突处理

在多人协作的项目中,冲突是不可避免的。以下是一些处理冲突的技巧:

  • 频繁同步:尽量在自己提交之前拉取远程的最新代码,并解决冲突。
  • 避免长时间拖延合并:如果开发周期较长,尽量频繁将自己的修改与主分支合并,减少出现复杂冲突的概率。

7. 私有小型团队的工作流程

  • 在一个小型私有团队中,可能会采用集中式的工作流。在这种情况下,团队成员通常拥有直接的写权限,可以直接将代码推送到主分支。这种工作流程较为简单,适用于团队成员较少且沟通较为直接的项目。
  • 示例:Git - 向一个项目贡献

8. ⭐私有管理团队的工作流程

  • 在大型私有团队中,通常会有一个整合者(例如项目经理或核心开发人员)来负责代码的合并工作。开发者会在自己创建的分支上进行工作,完成后通过拉请求(pull request)或合并请求(merge request)提交代码。这种工作流更为规范,适用于需要高质量代码管理的大型团队。
  • 示例:Git - 向一个项目贡献

9. 派生的公开项目

在许多公开项目中,你无法直接向主仓库提交代码,因为你没有写入权限。这时,派生(Fork)是常用的操作,具体步骤如下:

  1. 派生原项目:
    • 首先,你需要从原项目的页面点击“Fork”按钮。这样会创建一个你自己的仓库副本,通常在 GitHub、GitLab、BitBucket 等平台上。
  1. 克隆到本地:
    • 使用 git clone 克隆你派生的仓库到本地:
git clone <your-fork-url>
cd <project-directory>
  1. 创建一个新分支进行开发:
    • 在本地仓库中,创建一个新的分支来进行开发,避免直接在 master 分支上工作:
git checkout -b feature-branch
  1. 在新分支上做修改并提交:
    • feature-branch 上进行开发,提交修改:
git add .
git commit -m "Add feature A"
  1. 将修改推送到派生的仓库:
    • 修改完成后,你将分支推送到你自己的远程仓库:
git push origin feature-branch
  1. 创建拉取请求(Pull Request,PR):
    • 然后,前往 GitHub 或其他平台,进入你自己派生的仓库,在该仓库上创建一个 Pull Request。你需要选择将修改合并到原项目的 master 或其他目标分支。
    • 在 PR 描述中,清楚地说明你所做的更改,维护者会基于此来审查你的修改。
  1. 维护者审查和合并:
    • 项目的维护者会审查你的修改,可能会要求你进一步修改,或者直接合并你的工作。如果审查通过,维护者会将你的更改合并到原仓库。
  1. 总结
    1. 派生 是贡献代码的标准方式,尤其是在没有直接写入权限的情况下。
    2. 创建 Pull Request 是你提交修改的正式方式,维护者会在合并之前审查你的工作。
    3. 变基和冲突解决是常见的流程,以确保你的提交与原项目兼容。

10. 变基(Rebase)与冲突解决

  • 变基(Rebase): 如果在提交 PR 之前,原项目的 master 分支发生了更新,可能会出现合并冲突。这时,你可以通过 git rebase 将你的分支基于最新的 master 分支重新应用提交,避免冲突:
git checkout feature-branch
git fetch upstream
git rebase upstream/master

这会将你的更改基于最新的原仓库的 master 分支上,冲突解决后再推送。

  • 合并(Merge): 你也可以选择通过合并(git merge)来解决冲突,具体选择取决于项目的惯例。

结论

向一个项目贡献代码的流程是多种多样的,取决于项目的规模、工作流、贡献者的角色以及提交权限。最重要的是理解项目的工作流、遵循项目的提交准则,并保持代码的清晰与规范。在实际开发中,良好的协作和沟通是确保代码顺利合并和项目成功的关键。

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

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

相关文章

将 AzureBlob 的日志通过 Azure Event Hubs 发给 Elasticsearch(1.标准版)

问题 项目里使用了 AzureBlob 存储了用户上传的各种资源文件&#xff0c;近期 AzureBlob 的流量费用增长很快&#xff0c;想通过分析Blob的日志&#xff0c;获取一些可用的信息&#xff0c;所以有了这个需求&#xff1a;将存储账户的日志&#xff08;读写&#xff0c;审计&…

【json_object】mysql中json_object函数过长,显示不全

问题&#xff1a;json只显示部分 解决&#xff1a; SET GLOBAL group_concat_max_len 1000000; -- 设置为1MB&#xff0c;根据需要调整如果当前在navicat上修改&#xff0c;只有效本次连接和后续会话&#xff0c;重新连接还是会恢复默认值1024 在my.ini配置文件中新增或者修…

Flink底层架构与运行流程

这张图展示了Flink程序的架构和运行流程。 主要组件及功能&#xff1a; Flink Program&#xff08;Flink程序&#xff09;&#xff1a; 包含Program code&#xff08;程序代码&#xff09;&#xff0c;这是用户编写的业务逻辑代码。经过Optimizer / Graph Builder&#xff08…

你还在用idea吗

从VIM、Emacs&#xff0c;到eclipse、Jetbrains, 再到VSCode&#xff0c;过去的三十年时间&#xff0c;出现了这三代IDE产品。现在属于AI的时代来了&#xff0c;最新一代的产品像Cursor、Windsurf&#xff0c;就在昨天&#xff0c;字节跳动发布了最新的IDE&#xff0c;就叫Trae…

Linux TCP 之 RTT 采集与 RTO 计算

我们来看看 Linux TCP 采集 RTT 的函数 tcp_rtt_estimator&#xff0c;看注释&#xff0c;充满了胶着。 但在那个谨慎的年代&#xff0c;这些意味着什么&#xff1f; RTT 最初仅用于 RTO 的计算而不是用于调速&#xff0c;RTO 的计算存在两个问题&#xff0c;如果过估&#x…

学习ASP.NET Core的身份认证(基于JwtBearer的身份认证9)

测试数据库中只有之前记录温湿度及烟雾值的表中数据较多&#xff0c;在该数据库中增加AppUser表&#xff0c;用于登录用户身份查询&#xff0c;数据库表如下所示&#xff1a;   项目中安装SqlSugarCore包&#xff0c;然后修改控制器类的登录函数及分页查询数据函数&#xff…

leetcode-75-颜色分类

文章目录 1. 归并排序2. 计数3. 按照题目要求&#xff0c;原地腾挪 给定一个包含红色、白色和蓝色、共 n 个元素的数组 nums &#xff0c;原地 对它们进行排序&#xff0c;使得相同颜色的元素相邻&#xff0c;并按照红色、白色、蓝色顺序排列。 我们使用整数 0、 1 和 2 分别表…

html,css,js的粒子效果

这段代码实现了一个基于HTML5 Canvas的高级粒子效果&#xff0c;用户可以通过鼠标与粒子进行交互。下面是对代码的详细解析&#xff1a; HTML部分 使用<!DOCTYPE html>声明文档类型。<html>标签内包含了整个网页的内容。<head>部分定义了网页的标题&#x…

学习记录之原型,原型链

构造函数创建对象 Person和普通函数没有区别&#xff0c;之所以是构造函数在于它是通过new关键字调用的&#xff0c;p就是通过构造函数Person创建的实列对象 function Person(age, name) {this.age age;this.name name;}let p new Person(18, 张三);prototype prototype n…

go语言zero框架通过chromedp实现网页在线截图的设计与功能实现

在 GoZero 框架中实现网页在线截图的功能&#xff0c;可以通过集成 chromedp 库来控制 Chrome 浏览器进行截图。chromedp 是一个基于 Chrome DevTools 协议的 Go 包&#xff0c;可以用来在 Go 程序中模拟浏览器操作&#xff0c;如页面截图、DOM 操作、表单提交等。 下面是一个…

以 RFID 为钥,开启民兵装备管理的科技之门

民兵配备的武器及装备涵盖了各式武器、弹药及军事技术设备&#xff0c;其管理的优良直接决定了民兵的作战效能。鉴于民兵装备普遍面临老化、维护支援不充分等问题&#xff0c;迫切需要迅速建立完善的民兵装备管理新体系。这一转变将推动民兵装备由数量扩张转向质量提升&#xf…

电脑办公技巧之如何在 Word 文档中添加文字或图片水印

Microsoft Word是全球最广泛使用的文字处理软件之一&#xff0c;它为用户提供了丰富的编辑功能来美化和保护文档。其中&#xff0c;“水印”是一种特别有用的功能&#xff0c;它可以用于标识文档状态&#xff08;如“草稿”或“机密”&#xff09;、公司标志或是版权信息等。本…

llama-factory实战: 基于qwen2.5-7b 手把手实战 自定义数据集清洗 微调

基于qwen2.5 手把手实战 自定义数据集 微调&#xff08;llama-factory&#xff09; 准备工作1.数据集准备&#xff08;例:民法典.txt&#xff09;2.服务器准备&#xff08;阿里云 DSW 白嫖&#xff09;3.环境配置pip 升级模型下载微调助手 4.数据集处理脚本文件4.1文本分割(ber…

微透镜阵列精准全检,白光干涉3D自动量测方案提效70%

广泛应用的微透镜阵列 微透镜是一种常见的微光学元件&#xff0c;通过设计微透镜&#xff0c;可对入射光进行扩散、光束整形、光线均分、光学聚焦、集成成像等调制&#xff0c;进而实现许多传统光学元器件难以实现的特殊功能。 微透镜阵列&#xff08;Microlens Array&#x…

详解单片机学的是什么?(电子硬件)

大家好&#xff0c;我是山羊君Goat。 单片机&#xff0c;对于每一个硬件行业的从业者或者在校电子类专业的学生&#xff0c;相信对于这个名词都不陌生&#xff0c;但是掌没掌握就另说了。 那单片机到底学的是什么呢&#xff1f; 其实单片机在生活中就非常常见&#xff0c;目前…

基于Docker的Spark分布式集群

目录 1. 说明 2. 服务器规划 3. 步骤 3.1 要点 3.2 配置文件 3.2 访问Spark Master 4. 使用测试 5. 参考 1. 说明 以docker容器方式实现apache spark计算集群&#xff0c;能灵活的增减配置与worker数目。 2. 服务器规划 服务器 (1master, 3workers) ip开放端口备注ce…

9. 神经网络(一.神经元模型)

首先&#xff0c;先看一个简化的生物神经元结构&#xff1a; 生物神经元有多种类型&#xff0c;内部也有复杂的结构&#xff0c;但是可以把单个神经元简化为3部分组成&#xff1a; 树突&#xff1a;一个神经元往往有多个树突&#xff0c;用于接收传入的信息。轴突&#xff1a;…

web-view环境下,H5页面打开其他小程序

在Web-view环境下&#xff0c;H5页面无法直接打开其他小程序。正确的实现方式是先从H5页面跳转回当前小程序&#xff0c;再由当前小程序跳转到目标小程序。具体实现方法如下&#xff1a; H5页面跳转回小程序时&#xff0c;调用wx.miniProgram.navigateTo()方法。 小程序跳转到…

数据恢复常用方法(三)如何辨别固态硬盘故障类型

数据恢复首先需要辨别固态硬盘故障类型&#xff0c;只有先确认故障类型&#xff0c;才能进行下一步动作 如下是一种常见的场景&#xff0c;固态硬盘无法识别&#xff0c;接入电源与数据线&#xff0c;电脑的磁盘管理不显示任何信息。 第一步&#xff1a;确认硬件状态&#xff…

Android Studio打包APK

1.导出APK安装包 如果是首次打包&#xff0c;Create new 单击蓝色对话框右边文件夹&#x1f4c2;图标 &#xff0c;选择密钥保存路径&#xff0c;然后在下方File name对话框中填写您想要名称&#xff0c;再点击OK回到密钥创建对话框。 在此对话框中填写密码&#xff08;Passwo…