Git 分支管理:优化版本控制与应急处理的关键策略

这篇具有很好参考价值的文章主要介绍了Git 分支管理:优化版本控制与应急处理的关键策略。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

使用 Git 分支:轻松管理不同版本和应对紧急情况的最佳实践

使用 Git 分支

在 Git 中,分支是主仓库的新/独立版本。

假设你有一个大型项目,需要对其进行设计更新。

没有使用 Git 时:

  • 复制所有相关文件以避免影响实时版本
  • 开始进行设计工作,并发现代码依赖于其他文件中的代码,这些文件也需要更改!
  • 复制相关文件,确保每个文件依赖项引用正确的文件名
  • 紧急情况!项目的其他地方存在无关的错误,需要尽快修复!
  • 保存所有文件,记录你正在工作的副本的名称
  • 处理无关的错误并更新代码以修复它
  • 返回到设计工作,完成工作
  • 复制代码或重命名文件,以使更新后的设计出现在实时版本中

(两周后,你意识到未修复无关的错误,因为在修复之前你复制了文件)

使用 Git 时:

  • 使用名为 "new-design" 的新分支,直接编辑代码,而不影响主分支
  • 紧急情况!项目的其他地方存在无关的错误,需要尽快修复!
  • 从主项目创建名为 "small-error-fix" 的新分支
  • 修复无关的错误并将 "small-error-fix" 分支与主分支合并
  • 返回到 "new-design" 分支,完成工作
  • 合并 "new-design" 分支与主分支(提醒你正在缺少的小错误修复)

分支允许你在项目的不同部分上工作,而不影响主分支。

当工作完成后,可以将分支与主项目合并。

你甚至可以在不同分支之间切换,同时在不同项目上工作,而彼此不会互相干扰。

在 Git 中,分支非常轻量且快速!

创建新 Git 分支

让我们向我们的 index.html 页面添加一些新功能。

我们在本地仓库中工作,不希望干扰或可能破坏主项目。

所以我们创建一个新分支:

git branch hello-world-images

现在我们创建了一个名为 "hello-world-images" 的新分支。

让我们确认我们已经创建了一个新分支:

git branch
  hello-world-images
* master

我们可以看到新分支的名称为 "hello-world-images",但在 master 旁边的 * 指定我们当前在该分支上。

checkout 是用于检出分支的命令,将我们从当前分支移动到命令末尾指定的分支:

git checkout hello-world-images

现在我们已将当前工作区从 master 分支移动到新分支。

打开你最喜欢的编辑器并进行一些更改。

在此示例中,我们在工作目录中添加了一个图像(img_hello_world.jpg)和 index.html 文件的一行代码:

<!DOCTYPE html>
<html>
<head>
<title>Hello World!</title>
<link rel="stylesheet" href="bluestyle.css">
</head>
<body>

<h1>Hello world!</h1>
<div><img src="img_hello_world.jpg" alt="Hello World from Space"
style="width:100%;max-width:960px"></div>
<p>This is the first file in my new Git Repo.</p>
<p>A new line in our file!</p>

</body>
</html>

我们对一个文件进行了更改,并在工作目录中添加了一个新文件(与主分支相同的目录)。

现在检查当前分支的状态:

git status

在 hello-world-images 分支上,有文件更改,但该文件未准备好提交,img_hello_world.jpg 不在跟踪文件中。

因此,我们需要将这两个文件都添加到该分支的暂存区中:

git add --all

使用 --all 而不是单独的文件名将所有已更改的文件(新的、修改的和已删除的)放入暂存区。

检查分支的状态:

git status

在 hello-world-images 分支上,有文件更改,但未准备好提交。所以我们将这些更改提交到该分支:

git commit -m "Added image to Hello World"

现在我们有一个不同于 master 分支的新分支。

注意:在 checkout 命令上使用 -b 选项会创建一个新分支,并移动到该分支,如果该分支不存在的话。

切换分支

现在让我们看看工作在不同分支上有多么快速和容易,以及它是如何有效地工作的。

我们当前位于 hello-world-images 分支。我们向此分支添加了一个图像,所以让我们列出当前目录中的文件:

ls

我们可以看到新文件 img_hello_world.jpg,如果打开 html 文件,可以看到代码已经发生了变化。一切都按计划进行。

现在,让我们看看当我们切换到 master 分支时会发生什么

git checkout master

不再存在 img_hello_world.jpg!如果打开 html 文件,可以看到代码已经恢复到修改之前的状态。

看看工作在不同分支上有多么容易?以及它是如何允许你在不同的任务上工作的?

###

紧急分支

现在假设我们还没有完成 hello-world-images,但我们需要在 master 上修复一个错误。

我不想直接干预 master,也不想干扰 hello-world-images,因为它还没有完成。

所以我们创建一个新分支来处理紧急情况:

git checkout -b emergency-fix

现在我们已经从 master 创建了一个新分支,并切换到它。我们可以安全地修复错误,而不会干扰其他分支。

让我们修复我们想象中的错误:

<!DOCTYPE html>
<html>
<head>
<title>Hello World!</title>
<link rel="stylesheet href="bluestyle.css">
</head>
<body>

<h1>Hello world!</h1>
<p>This is the first file in my new Git Repo.</p>
<p>This line is here to show how merging works.</p>

</body>
</html>

我们在该文件中进行了更改,现在需要将这些更改传输到 master 分支。

检查分支的状态:

git status

在 emergency-fix 分支上,有文件更改,但未准备好提交,所以我们需要将该文件暂存,然后提交:

git add index.html
git commit -m "updated index.html with emergency fix"

现在,我们已经为 master 分支准备好一个修复。需要合并这两个分支。

最后

为了方便其他设备和平台的小伙伴观看往期文章:

微信公众号搜索:Let us Coding,关注后即可获取最新文章推送

看完如果觉得有帮助,欢迎 点赞、收藏、关注文章来源地址https://www.toymoban.com/news/detail-837712.html

到了这里,关于Git 分支管理:优化版本控制与应急处理的关键策略的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Chromium的Git版本分支合并、切换等管理

    源码同步 1)git 初始配置 2)创建目录 3)拉取代码 fetch chromium 4)同步依赖库 gclient sync 5)源码更新 进入src目录,运行 git rebase-update。 同步完成后再运行gclinet sync -D 更新第三方库等。 远程tag 创建本地相应版本支使用命令: git checkout -b 114.0.5735.134 114.0.5735.134 后面需要运行

    2024年02月08日
    浏览(30)
  • Git版本管理(02)patch操作和分支操作整理

    使用git diff用于显示当前工作区与暂存区或提交历史之间的差异,如果使用它生成patch,则需要使用git apply命令来引入patch,比如: 使用git format-patch生成patch,如下所示: 打包好后会生成0001-XXX.patch 这样格式的patch,使用git am(自动提交) /git apply 来merge patch即可。 @1 批量am操

    2024年02月03日
    浏览(55)
  • 如何通过TortoiseGit工具查看Git管理的版本分支图

    先上一张图: 选中仓库,鼠标右击 - TortoiseGit - (版本分支图)Revision graph,即可打开版本分支图。 红色:当前分支,也就是当前正在使用的分支。 绿色:本地分支,也就是存在于本地 Git 仓库中的分支,它们存储在你的计算机上。 粉红:远端分支,也就是存在于远程 Git 仓库

    2024年02月04日
    浏览(50)
  • Git的常用命令,及还原文件的指定版本,及分支管理

    一.git 常用命令 二.还原文件的指定版本(从版本库中恢复文件) 怎么查看最后一次提交id 显示下面的结果 然后使用下面命令,就会恢复之前的修改 三.分支管理 创建分支分为两种情况 一.第一种情况 创建仓库时就把分支创建出来 2.第二种情况 已有仓库,在创建分支 3.修改分

    2024年02月11日
    浏览(41)
  • Git企业开发控制理论和实操-从入门到深入(三)|分支管理

    那么这里博主先安利一些干货满满的专栏了! 首先是博主的高质量博客的汇总,这个专栏里面的博客,都是博主最最用心写的一部分,干货满满,希望对大家有帮助。 高质量博客汇总 然后就是博主最近最花时间的一个专栏《Git企业开发控制理论和实操》希望大家多多关注!

    2024年02月11日
    浏览(41)
  • Git (版本控制,git安装和配置,git代码托管服务,git操作本地远程仓库,分支,idea整合git)【看这一片就够】

    目录 一、版本控制介绍 1. 版本控制介绍 2. 版本控制工具 3. git简介 二、git安装与配置 1. 下载git 2. 安装git 2. 配置git 三、git代码托管服务 1. 常见的git代码托管服务 2. 注册码云帐号【这里介绍一种的用法,其它也是一样的操作】 3. 创建远程仓库 四、git命令-操作本地仓库 1. 获

    2024年04月14日
    浏览(66)
  • 部署Git版本控制系统 | 优化Web服务器

    前序文章: https://blog.csdn.net/shengweiit/article/details/135193074 部署git版本控制系统,管理网站代码 基于ssh协议的服务器 基于git协议的服务器 基于HTTP协议的服务器 上传代码到版本库 1. 安装软件包,创建空仓库

    2024年02月04日
    浏览(34)
  • 云计算项目四:部署Git版本控制系统 | 优化Web服务器

    前序文章: https://blog.csdn.net/shengweiit/article/details/135193074 部署git版本控制系统,管理网站代码 基于ssh协议的服务器 基于git协议的服务器 基于HTTP协议的服务器 上传代码到版本库 1. 安装软件包,创建空仓库

    2024年01月24日
    浏览(41)
  • Git 与 Maven:企业级版本管理与版本控制规范设计

    当今,许多开发人员熟悉 GitFlow 工作流程,但往往忽略了 GitFlow 如何与 Maven 版本控制结合,尤其是在管理 snapshot 和 release 版本时的最佳实践。本文旨在整合 GitFlow 工作流程与 Maven 版本管理,提出一个统一的企业级规范,以供开发人员参考。 GitFlow 是一种流行的分支管理模型

    2024年02月04日
    浏览(40)
  • Linux | 分布式版本控制工具Git【版本管理 + 远程仓库克隆】

    本文来为读者介绍一下分布式版本控制工具Git,可能你听说过Gitee/GitHub,里面都带有git的字样,那它们和Git之间有什么关联呢❓ Git又是何物,让我们一起走进本文的学习📖 Git(读音为/gɪt/)是一个 开源的分布式版本控制系统 ,可以有效、高速地处理从很小到非常大的项目

    2024年02月01日
    浏览(51)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包