【随笔】Git 高级篇 -- 远程跟踪分支 git checkout -b | branch -u(三十五)

请添加图片描述

  • 💌 所属专栏:【Git】

  • 😀 作  者:我是夜阑的狗🐶

  • 🚀 个人简介:一个正在努力学技术的CV工程师,专注基础和实战分享 ,欢迎咨询!

  • 💖 欢迎大家:这里是CSDN,我总结知识的地方,喜欢的话请三连,有问题请私信 😘 😘 😘

您的点赞、关注、收藏、评论,是对我最大的激励和支持!!!🤩 🤩 🤩

请添加图片描述

文章目录

  • 前言
  • 一、远程跟踪分支
      • 1、介绍
      • 2、示范
        • 第一种方法
        • 第二种方法
      • 3、实战
        • (1)第一种方法
        • (2)第二种方法
  • 总结


前言

  大家好,又见面了,我是夜阑的狗🐶,本文是专栏【Git】专栏的第三十五篇文章;
  这是今天学习到Git 高级篇 – 远程跟踪分支 💖💖💖,开启新的征程,记录最美好的时刻🎉,每天进步一点点。
  专栏地址:【Git】 , 此专栏是我是夜阑的狗对Git,Gitee等工具使用过程的总结,希望能够加深自己的印象,以及帮助到其他的小伙伴😉😉。
  如果文章有什么需要改进的地方还请大佬不吝赐教👏👏。


一、远程跟踪分支

  这里给大家推荐一个好用的 Git在线练习地址。在这练习网站里面也有自己的教程,就让我们一步一步跟着教程学习吧,记录下自己的所感所悟。前面已经简单的学习了怎么合并远程仓库,接下来就让我们看看在实际项目过程中是怎么远程跟踪分支的吧。话不多说,让我们原文再续,书接上回吧。

请添加图片描述

1、介绍

  在前几节课程中有件事儿挺神奇的,Git 好像知道 maino/main 是相关的。当然这些分支的名字是相似的,可能会让你觉得是依此将远程分支 main 和本地的 main 分支进行了关联。这种关联在以下两种情况下可以清楚地得到展示:

  • pull 操作时, 提交记录会被先下载到 o/main 上,之后再合并到本地的 main 分支。隐含的合并目标由这个关联确定的。
  • push 操作时, 我们把工作从 main 推到远程仓库中的 main 分支(同时会更新远程分支 o/main) 。这个推送的目的地也是由这种关联确定的!

  直接了当地讲,maino/main 的关联关系就是由分支的“ remote tracking ”属性决定的。main 被设定为跟踪 o/main —— 这意味着为 main 分支指定了推送的目的地以及拉取后合并的目标。
  你可能想知道 main 分支上这个属性是怎么被设定的,你并没有用任何命令指定过这个属性呀!好吧,当你克隆仓库的时候,Git 就自动帮你把这个属性设置好了。
  当你克隆时, Git 会为远程仓库中的每个分支在本地仓库中创建一个远程分支(比如 o/main)。然后再创建一个跟踪远程仓库中活动分支的本地分支,默认情况下这个本地分支会被命名为 main
  克隆完成后,你会得到一个本地分支(如果没有这个本地分支的话,你的目录就是“空白”的),但是可以查看远程仓库中所有的分支(如果你好奇心很强的话)。这样做对于本地仓库和远程仓库来说,都是最佳选择。
  这也解释了为什么会在克隆的时候会看到下面的输出:

local branch “main” set to track remote branch “o/main”

  那我们能自己指定这个属性吗?当然可以啦!你可以让任意分支跟踪 o/main,然后该分支会像 main 分支一样得到隐含的 push 目的地以及 merge 的目标。 这意味着你可以在分支 totallyNotMain 上执行 git push,将工作推送到远程仓库的 main 分支上。

2、示范

  有两种方法设置这个属性,第一种就是通过远程分支切换到一个新的分支,执行:

git checkout -b totallyNotMain o/main

  就可以创建一个名为 totallyNotMain 的分支,它跟踪远程分支 o/main

第一种方法

  闲话少说,咱们先看看演示!我们切换到一个名叫 foo 的新分支,让其跟踪远程仓库中的 main 分支。

git checkout -b foo o/main
git pull

  运行结果如下图所示:

请添加图片描述

  正如你所看到的, 我们使用了隐含的目标 o/main 来更新 foo 分支。需要注意的是 main 并未被更新!git push 同样适用

git checkout -b foo o/main
git commit
git push

  运行结果如下图所示:

请添加图片描述

  我们将一个并不叫 main 的分支上的工作推送到了远程仓库中的 main 分支上

第二种方法

  另一种设置远程追踪分支的方法就是使用:git branch -u 命令,执行:

git branch -u o/main foo

  这样 foo 就会跟踪 o/main 了。如果当前就在 foo 分支上,还可以省略 foo

git branch -u o/main

  看看这种方式的实际的效果…

git branch -u o/main foo
git commit
git push

  跟之前一样, 但这个命令更明确!运行结果如下图所示:

请添加图片描述

  OK!本节我们在不切换到 main 分支的情况下将工作推送到的远程仓库中的 main 分支上。因为这是高级课程, 就不做过多的提示了! 😛

3、实战

  从前面了解到具体的实现的步骤,就可以开始实战啦。这里先给大家说一下这个练习网站的一些使用技巧,

  • help 指令

  执行这个命令后就会有个帮助信息的弹窗。

在这里插入图片描述

  • levels 指令

  执行完这个命令之后就能看到关卡目录了。

在这里插入图片描述

  • 目标

在这里插入图片描述

  注意,这里的目标要实现得一摸一样,才能通过。

  • 开始结构

在这里插入图片描述

(1)第一种方法

  接下来就让我们来看看是怎么操作的吧。

  • Step 1、跟踪远程分支

  首先需要创建新的分支来跟踪 o/main 分支。

git checkout -b side o/main

  很简单吧,运行结果如下图所示:

在这里插入图片描述

  • Step 2、提交

  在本地分支进行一次提交。

git commit

  运行结果如下图所示:

在这里插入图片描述

  • Step 3、拉取合并分支

  这里是最关键的一步,拉取远程分支数据并以 rebase 的方式合并到本地分支中,实际项目过程中可能还需要解一下冲突。

git pull --rebase

  运行结果如下图所示:

请添加图片描述

  • Step 4、推送修改

  将主分支更新至最新状态之后,就可以将本地的修改点上传至远程分支了。

git push

  运行结果如下图所示:

在这里插入图片描述

(2)第二种方法

  除了第一种方法之外,当然也可以先创建新分支,然后用 branch 命令去跟踪远程分支,接下来就让我们来看看是怎么操作的吧。

  • Step 1、创建新分支

  创建新分支 side 为后续跟踪远程分支做准备。

git checkout -b side

  运行结果如下图所示:

在这里插入图片描述

  • Step 2、远程跟踪

  选择本地分支 side 跟踪远程分支。

git branch -u o/main side

  运行结果如下图所示:

在这里插入图片描述

  • Step 3、提交

  在本地分支进行一次提交。

git commit

  运行结果如下图所示:

在这里插入图片描述

  • Step 4、拉取合并分支

  这里是最关键的一步,拉取远程分支数据并以 rebase 的方式合并到本地分支中,实际项目过程中可能还需要解一下冲突。

git pull --rebase 

  运行结果如下图所示:

请添加图片描述

  • Step 5、推送分支

  将主分支更新至最新状态之后,就可以将本地的修改点上传至远程分支了。

git push

  运行结果如下图所示:

在这里插入图片描述

  达成目标之后就会有成功的提示。

在这里插入图片描述


总结

  感谢观看,如果觉得有帮助,请给文章点个赞吧,让更多的人看到。🌹 🌹 🌹

在这里插入图片描述

  也欢迎你,关注我。👍 👍 👍

  原创不易,还希望各位大佬支持一下,你们的点赞、收藏和留言对我真的很重要!!!💕 💕 💕 最后,本文仍有许多不足之处,欢迎各位认真读完文章的小伙伴们随时私信交流、批评指正!下期再见。🎉

更多专栏订阅:

  • 😀 【LeetCode题解(持续更新中)】
  • 🌼 【鸿蒙系统】
  • 👑 【Python脚本笔记】
  • 🚝 【Java Web项目构建过程】
  • 💛 【微信小程序开发教程】
  • 【JavaScript随手笔记】
  • 🤩 【大数据学习笔记(华为云)】
  • 🦄 【程序错误解决方法(建议收藏)】
  • 🚀 【软件安装教程】



订阅更多,你们将会看到更多的优质内容!!

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

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

相关文章

go语言函数/方法入参对象方法 接口interface约束示例

go语言使用泛型接口约束可以约束指定的对象参数 必须具备指定的方法 或者必须实现了指定的接口 1个或者多个接口(通过接口继承实现), 这个在面向api的接口编程中应用非常广泛,也非常实用,废话不多说,直接上…

向银行家应用程序添加日期

● 首先我们将下面图片上的时间更换成现在的时间 const now new Date(); const day now.getDate(); const month now.getMonth() 1; const year now.getFullYear(); const hour now.getHours(); const min now.getMinutes();labelDate.textContent ${day}/${month}/$…

parallelsdesktop19密钥激活 PD19虚拟机完整图文安装教程

Parallels Desktop 19 (简称 PD 19)是最新发布的 macOS 平台的 windows 虚拟机,本文是使用 Parallels Desktop 19 虚拟机安装 Windows 的详细图文破解安装教程。 一下载安装 Parallels Desktop 软件下载完成后打开,双击打开 安装.dmg Para…

3. 深度学习笔记--优化函数

深度学习——优化器算法Optimizer详解(BGD、SGD、MBGD、Momentum、Adagrad、Adadelta、RMSprop、Adam、Nadam、AdaMax、AdamW ) 0. GD (梯度下降) Gradient Descent(梯度下降)是一种迭代优化算法&#xf…

【C】每日一题 53 最大子数组和

给你一个整数数组 nums ,请你找出一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和。 子数组 是数组中的一个连续部分。 这是一个经典的动态规划问题,可以通过遍历数组并利用动态规划的思想来解决。…

汇昌联信电商:拼多多新手怎么做店铺的免费流量会慢慢起来?

在拼多多上开店,新手们往往面临着如何吸引免费流量的挑战。毕竟,流量是店铺生存和发展的血脉,没有流量,就没有销量,店铺也就失去了生命力。那么,作为拼多多新手,如何做才能让店铺的免费流量慢慢…

初识C语言——第十九天

for循环 1.简单概述 2.执行流程 3.建议事项:

RuoYi-Vue-Plus (SpringCache、CacheManager、@Cacheable、缓存雪崩、击穿、穿透)

一、概述 1、SpringCache是Spring提供的一个缓存框架,在Spring3.1版本开始支持将缓存添加到现有的spring应用程序中,在4.1开始,缓存已支持JSR-107注释和更多自定义的选项。 2、SpringCache利用了AOP,实现了基于注解的缓存功能&…

Android中使用USB进行通信的4种方式

在Android设备中,通过USB与外部设备通信是一种常见的需求,尤其是在嵌入式系统、IoT设备、以及各种专业硬件的交互中。以下是Android设备通过USB进行通信的四种主要方法: 1. 控制传输(Control Transfer) 控制传输是所…

基于Java的qq截图工具参考论文(论文 + 源码)

【免费】基于Java的qq截图工具.zip资源-CSDN文库https://download.csdn.net/download/JW_559/89304179 基于Java的qq截图工具 摘要 当今时代是飞速发展的信息时代,人们在对信息的处理中对图像的处理量与日俱增,这一点在文档人员上显得非常突出。 本软…

Linux下Telemac-Mascaret源码编译安装及使用

目录 软件介绍 基本依赖 其它可选依赖 一、源码下载 二、解压缩 三、编译安装 3.1 修改环境变量设置文件 3.2 修改配置文件 3.3 编译安装 四、算例运行 软件介绍 TELEMAC-MASCARET是法国电力集团(EDF)的法国国立水利与环境实验室开发的一款研究水动力学和水文学领域的…

宿舍管理系统代码详解(登录界面)

之前已经对这个管理系统进行了大体上的结构的展现,后面的篇章将对其中的前端代码进行详细的介绍与展示。 目录 一、数据库建表 二、登录界面前端代码 1.样式展示 2.代码详解 (1)template部分 (2)script部…

DC/DC 隔离定电,压输入电源(0.1-3W)介绍

定电压输入非稳压输出 SMD(0.25-2W)系列,典型性能:直流输入、直流输出隔离型模块电源SMD 表贴型产品,完全实现采用全自动贴片机来组装和满足回流焊工艺,大大提高产能和人工费用。此产品小,效率高,低输出纹波及提供 300…

Flutter 中的 MaterialButton 小部件:全面指南

Flutter 中的 MaterialButton 小部件:全面指南 在 Flutter 中,MaterialButton 是 Material Design 风格中的一种按钮,它提供了一种简单而直观的方式来创建符合 Material Design 指南的按钮。MaterialButton 支持多种形状、颜色和大小&#x…

SSH 免密登录,设置好仍然需要密码登录解决方法

说明: ssh秘钥登录设置好了,但是登录的时候依然需要提供密码 查看系统安全日志,定位问题 sudo cat /var/log/auth.log或者 sudo cat /var/log/secure找到下面的信息 Authentication refused: bad ownership or modes...(网上的…

重大升级 | OpenSCA SaaS全面接入供应链安全情报!

结合社区用户反馈及研发小伙伴的积极探索, OpenSCA 项目组再次发力,SaaS版本重大升级啦! 用户的需求是OpenSCA前进的动力,欢迎更多感兴趣的朋友们积极试用和反馈~ 更 新 内 容 1.全面接入云脉XSBOM供应链安全情报 2.强大的资产…

Nginx-01-Nginx 是什么? 能做什么?

nginx 系列 Nginx-01-聊一聊 nginx Nginx-01-Nginx 是什么 Nginx-02-为什么使用 Nginx Nginx-02-Nginx Ubuntu 安装 windows10 WSL ubuntu 安装 nginx 实战笔记 Nginx-02-基本使用 Nginx-03-Nginx 项目架构 Nginx-04-Docker Nginx Nginx-05-nginx 反向代理是什么&…

【AtCoder Beginner Contest 353】C - Sigma Problem 题解

【AtCoder Beginner Contest 353】C - Sigma Problem 题解 文章目录 【AtCoder Beginner Contest 353】C - Sigma Problem 题解题目大意大致思路代码 题目大意 给出一个函数 f ( x , y ) ( x , y ) f(x,y) (x,y) f(x,y)(x,y),求: ∑ i 1 N − 1 ∑ j…

嫦娥六号揭秘真相:阿波罗登月是真是假?一文终结所有疑问!

近期,嫦娥六号的成功发射如同璀璨的星辰,再次将人们的视线聚焦于浩瀚的宇宙,与此同时,网络上关于美国阿波罗登月是否造假的争议也如潮水般涌现。一些声音宣称,嫦娥六号的发射为揭示美国阿波罗登月任务的真实性提供了关…

宝塔面板各种疑难杂症处理命令教程

下载地址:宝塔面板各种疑难杂症处理命令教程 这份宝塔面板各种疑难杂症处理命令教程,可以解决市面上遇到的各种难题,建议有技术能行的下载使用,小白也可以下载来学习可以帮助你解决宝塔面板遇到的各种难题