Git常见分支问题各个击破

简介: 本文首发于公众号“AntDream”,欢迎微信搜索“AntDream”或扫描文章底部二维码关注,和我一起每天进步一点点为什么已经推到远程的分支,我本地checkout的时候还是提示找不到分支?首先我们要弄清楚的是,checkout 是本地命令,不跟远程仓库打交道。

本文首发于公众号“AntDream”,欢迎微信搜索“AntDream”或扫描文章底部二维码关注,和我一起每天进步一点点

为什么已经推到远程的分支,我本地checkout的时候还是提示找不到分支?

首先我们要弄清楚的是,checkout 是本地命令,不跟远程仓库打交道。我们基于远程分支新建一个分支时一般会这样操作:

git checkout -b XXX origin/XXX

实际上,上面的命令并不是从远程仓库拉分支下来切换,而是从我们本地的远程引用中切换新分支,也就是从我们本地的Git仓库中的 refs/remotes 目录下面。

而本地的远程引用只有在和远程仓库沟通时才会更新。换句话说,我们的本地仓库很多时候并不是最新的,其他小伙伴推到远程的分支我们如果不拉取是没有的。

所以我们需要先更新一下,把新的分支拉到我们的本地仓库中,执行一下 git fetch 就好了。

Git fetch和Git pull

git fetch 是从远程仓库拉取本地没有的数据,不会修改工作目录的内容。获取的数据包括远程新的分支、新的提交等,更新的是远程引用。

git pull 基本就相当于 git fetch 加上 git merge,也就是除了拉取新的数据外,它还会把当前分支对应的远程分支上的内容 merge 到当前分支。所以很多时候,我们用 git pull 以后都会报冲突,就是因为Git自己执行了merge操作。

非常重要的是,如果我们是和其他小伙伴在同一个分支合作开发,我们在 push 之前,必须先拉取一下。

回滚远程仓库时,git push origin HEAD --force的原理是什么?实际上是做了啥操作?

实际上是把本地分支指向的 commit 强制更新到了远程对应的分支。

如何用命令删除远程分支?删除远程仓库分支实际是干了啥?(谨慎操作)

// -D 大写,表示强制删除
git branch -d branchName

我们知道分支实际上是 resf/heads/下面的一个文件,里面保存的是最新的一次 commit 的SHA-1值。实际上,删除分支就是删除了这个引用文件,那删除远程仓库的分支也就是删除远程仓库下面的对应分支的引用。

明白了删除远程仓库分支的原理,我们来看看删除远程仓库分支的命令:

git push origin :branchName

上面命令的意思就是将远程仓库的 branchName 的分支引用置为空。

引用规格

上面的命令实际上是一种引用规格的应用,引用规格的形式为 :,其中 <src><dst> 是一个模式(pattern)。之前在讲到 git fetch 的时候我们提到了 Git仓库目录下的 config文件:

[remote "origin"]
    url = https://github.com/schacon/simplegit-progit
    fetch = +refs/heads/*:refs/remotes/origin/*

上面的 fetch 实际上就是应用到了引用规格,含义之前已经提到过,就是把远程仓库 refs/heads/ 目录下的引用更新到本地仓库的 refs/remotes/origin/

实际上,我们还可以设置 push 操作的引用规格。比如我们想将当前的 master 分支推送到远程仓库的mymaster 分支,我们就可以这样:

git push origin master:refs/heads/mymaster

更进一步的,如果我们想把自己分支都推送到远程仓库的 KAE 目录下,我们就可以在 config 目录下更新一条关于 push 操作的引用规格:

[remote "origin"]
    url = https://github.com/schacon/simplegit-progit
    //fetch中冒号前面的表示是远程仓库的引用,后面的表示那些远程引用在本地所对应的位置
    fetch = +refs/heads/*:refs/remotes/origin/*
    //push相反,前面的是本地的引用位置,后面的表示远程仓库的地址
    push = refs/heads/*:refs/heads/ant/*

经过上面的设置以后,我们每次 push 都会把本地的分支推送到远程仓库的 ant/* 分支。


欢迎关注我的公众号查看更多精彩文章!
AntDream

目录
相关文章
|
1月前
|
开发工具 git
git学习四:常用命令总结,包括创建基本命令,分支操作,合并命令,压缩命令,回溯历史命令,拉取命令
这篇文章是关于Git常用命令的总结,包括初始化配置、基本提交、分支操作、合并、压缩历史、推送和拉取远程仓库等操作的详细说明。
112 1
git学习四:常用命令总结,包括创建基本命令,分支操作,合并命令,压缩命令,回溯历史命令,拉取命令
|
1月前
|
开发工具 git 开发者
关于git 解决分支冲突问题(具体操作,包含截图,教你一步一步解决冲突问题)
本文通过具体操作和截图,详细讲解了如何在Git中解决分支冲突问题,包括如何识别冲突、手动解决冲突代码、提交合并后的代码,以及推送到远程分支。
349 3
关于git 解决分支冲突问题(具体操作,包含截图,教你一步一步解决冲突问题)
|
5月前
|
项目管理 开发工具 git
Git项目管理——分支(三)
Git项目管理——分支(三)
70 2
|
2月前
|
缓存 开发工具 git
Git创建分支以及合并分支
在Git中,创建分支使用`git branch [branch_name]`,切换分支使用`git checkout [branch_name]`。修改文件后,通过`git add [file]`添加到暂存区,然后`git commit`提交到本地仓库。如果是新建分支的第一次推送,使用`git push origin [branch_name]`推送到远程仓库,之后可以简化为`git push`。合并分支时,使用`git merge [branch_name]`将指定分支的更改合并到当前分支。
69 2
Git创建分支以及合并分支
|
1月前
|
开发工具 git
Git分支使用总结
Git分支使用总结
35 1
|
2月前
|
存储 Linux 开发工具
Git基础命令,分支,标签的使用【快速入门Git】
本文详细介绍了Git版本控制系统的基础概念和常用命令,包括工作区、暂存区和版本库的区别,文件状态的变化,以及如何进行文件的添加、提交、查看状态、重命名、删除、查看提交历史、远程仓库操作和分支管理,还涉及了Git标签的创建和删除,旨在帮助读者快速入门Git。
Git基础命令,分支,标签的使用【快速入门Git】
|
2月前
|
测试技术 开发工具 git
掌握 Git 分支策略:提升你的版本控制技能
在现代软件开发中,版本控制至关重要,Git 作为最流行的分布式版本控制系统,其分支管理策略对于高效协作和代码维护尤为重要。本文介绍了几种常用的 Git 分支策略,包括主线开发模型、功能分支模型、Gitflow 工作流和 Forking 工作流,并探讨了如何根据项目需求选择合适的分支模型。通过保持 `master` 分支稳定、及时合并清理分支、使用命名规范、利用 Pull Request 进行代码审查及自动化测试等最佳实践,可以显著提升团队协作效率和软件质量。掌握这些策略将帮助开发者更好地管理代码库,加快开发流程。
|
3月前
|
开发工具 git 开发者
|
3月前
|
项目管理 开发工具 git
|
3月前
|
存储 小程序 安全
【技巧】git stash用的好,切换分支随便搞
本文详细介绍了 Git 中的 `git stash` 命令,帮助你在切换分支时临时保存未提交的更改。通过实际操作示例,展示了如何使用 `git stash` 的各种命令,如 `save`、`list`、`apply` 等。无论你是初学者还是有一定经验的开发者,都能从中受益。
64 0
【技巧】git stash用的好,切换分支随便搞