图解Git——远程分支《Pro Git》

简介: 远程分支是 Git 中用于管理分布式协作的关键概念。远程引用指向远程仓库中的分支和标签,常用 `git ls-remote` 或 `git remote show` 查看。日常开发中,通常使用远程跟踪分支(如 `origin/main`)与远程分支交互,简化远程仓库状态的管理和使用。远程跟踪分支记录远程分支的状态,但本身只读。

远程分支

  • 远程引用:
    • 远程引用是远程仓库中分支、标签等的指针,可以通过 git ls-remotegit remote show 查看。
    • 但在日常开发中,更常用远程跟踪分支(如 origin/main)与远程分支交互,简化了对远程仓库状态的管理和使用。
  • 远程跟踪分支: 它是本地 Git 对远程分支状态的一个记录。它可以帮助我们了解远程分支的最新状态,但它本身是只读的,不能直接操作。
    • 示例:
      • 假设远程仓库有一个分支 main
      • 你本地的远程跟踪分支是 origin/main
      • 初次克隆仓库时,origin/main 和远程的 main 同步,指向相同的提交。
      • 如果团队中的其他人向远程的 main 分支提交了新的代码,而你没有运行 git fetchgit pull,你的 origin/main 不会自动更新。
      • 只有当你运行 git fetch 时,origin/main 才会更新,指向远程 main 的最新状态。

1. 远程分支实例

  1. 克隆后的服务器与本地仓库:
    1. 设你的网络里有一个在 git.ourcompany.com 的 Git 服务器。 如果你从这里克隆,Git 的 clone 命令会为你自动将其命名为 origin,拉取它的所有数据, 创建一个指向它的 master 分支的指针,并且在本地将其命名为 origin/master。 Git 也会给你一个与 origin 的 master 分支在指向同一个地方的本地 master 分支,这样你就有工作的基础。

    2. 编辑

  1. 本地与远程的工作可以分叉:
    1. 本地的 master分支做了些工作,同时有其他人推送提交到 git.ourcompany.com并更新了 master分支。即使这样,如果你不向 origin拉取数据,你的 origin/master 指针就不会移动。

    2. 编辑

  1. git fetch 更新你的远程跟踪分支:
    1. 运行 git fetch origin 同步远程仓库数据:查找“origin”是哪个服务器(本例中,是 git.ourcompany.com),从中抓取本地没有的数据,并且更新本地数据库,移动 origin/master 指针到更新后的位置。

    2. 编辑

  1. 添加另一个远程仓库:
    1. 为了展示多个远程服务器及其分支的管理,可以为项目添加一个内部开发服务器(如 git.team1.ourcompany.com),专用于某个团队。通过 git remote add 命令,将该服务器添加为远程引用,并命名为 teamone,作为简短标识。

    2. 编辑

  1. 远程跟踪分支 teamone/master
    1. 运行 git fetch teamone **来获取远程服务器 teamone 上你本地尚未拥有的数据。

    2. 如果该服务器的数据是当前 origin 服务器数据的子集,Git 不会拉取新数据,但会创建一个远程跟踪分支 teamone/master,指向 teamone 的主分支提交点。

    3. 编辑


2. 推送(push)

  1. 分享分支—— git push <remote> <branch>
    1. 可以将本地分支推送到具有写权限的远程仓库。
    2. 推送是显式的,未推送的分支不会同步到远程。这样,你可以保留私人分支,仅共享需要协作的主题分支。
    3. 示例:
      1. git push origin serverfix:将本地分支 serverfix 推送到远程分支 serverfix
      2. 此命令是refs/heads/serverfix:refs/heads/serverfix 命令的简写。
  1. 重命名远程分支—— git push origin serverfix:awesomebranch
    1. 若需要不同的远程分支名称,例如将本地分支 serverfix 推送为远程分支 awesomebranch
  1. 凭据缓存—— git config --global credential.helper cache
    1. 如果使用 HTTPS 推送,Git 会要求输入用户名和密码。为了避免每次都输入,可以设置凭据缓存:
  1. 获取远程分支—— git fetch 可同步远程分支
    1. 示例:git fetch origin 会同步 origin/serverfix 指向远程的 serverfix 分支,但不会自动创建本地分支。
  1. 合并或创建本地分支—— git merge origin/serverfix / git checkout -b serverfix origin/serverfix
    1. 合并远程分支内容: git merge origin/serverfix
    2. 基于远程分支创建可编辑的本地分支: git checkout -b serverfix origin/serverfix创建本地分支 serverfix 并设置与 origin/serverfix 的追踪关系。

3. 跟踪分支

3.1. 跟踪分支的概念

  • 跟踪分支 是与远程分支有直接关系的本地分支。
  • 当你运行 git pull 时,Git 自动识别:
    • 从哪个远程仓库获取数据。
    • 合并到哪个本地分支。

3.2. 跟踪分支的创建

  • 自动创建:
    • 当克隆一个仓库时,master 分支默认会跟踪 origin/master
  • 手动创建:
    • 命令:git checkout -b <本地分支> <远程分支>
    • 简化命令:git checkout --track <远程分支>
    • 再次简化(如果名字唯一匹配):git checkout <远程分支>
  • 重命名本地分支:
    • 命令:git checkout -b <新分支名> <远程分支>

3.3. 管理跟踪分支

  • 设置已有本地分支的跟踪:
    • 命令:git branch -u <远程分支>
  • 检查所有跟踪分支信息:
    • 命令:git branch -vv
    • 包含分支的跟踪状态(领先、落后)。

3.4. 拉取(pull)

  • 基本原理
    • git pull 是一个复合命令,等效于 git fetch(从远程获取最新更新)+ git merge(将更新合并到当前分支)。
    • 它的作用是将远程分支的变化应用到本地分支上。
  • 详细过程
    1. git fetch:从远程仓库获取最新的提交,并将其存储在本地的远程分支(如 origin/master)。
    2. git merge:将这些远程分支的更新合并到当前分支。
  • 推荐用法
    • 为了更清晰控制更新过程,建议手动执行以下步骤:
      1. 使用 git fetch 仅抓取远程更新,不自动合并。
      2. 根据需要决定如何合并(例如使用 git mergegit rebase)。
  • 示例
    • 单独拉取和查看远程分支的变化:
git fetch origin
git log HEAD..origin/master --oneline

    • 合并变化到当前分支:
git merge origin/master

  • 注意事项
    • 如果分支没有设置跟踪关系,git pull 会提示需要指定远程分支。
    • 避免不必要的冲突,尤其是多人协作时,拉取前可以先查看差异。
  • 查看差异:
    • 方法 1:通过 git fetchgit diff 查看差异
      • 先执行 git fetch origin 更新远程分支信息:这只会更新本地的远程跟踪分支(如 origin/master),不会修改当前分支的内容。
      • 使用 git diff HEAD origin/<远程分支名> :查看本地分支与远程分支的差异
    • 方法 2:通过 git log 查看提交历史的差异
      • 如果只关心新增的提交而不是具体的代码变化,可以使用 git log 查看提交历史:
      • 查看远程分支的新增提交git log HEAD..origin/<远程分支名> --oneline
        • HEAD..origin/<远程分支名>:表示显示当前分支落后于远程分支的提交记录。
      • 查看本地分支的新增提交(远程分支未同步的部分)git log origin/<远程分支名>..HEAD --oneline
        • 这可以帮助确认本地分支的哪些提交尚未推送到远程分支。
    • 方法 3:使用 git status 检查是否同步
      • 在设置了跟踪关系的分支上,git status 会显示当前分支与远程分支的同步情况。
    • 方法 4:检查所有分支的同步状态
      • 使用 git branch -vv 查看所有本地分支的状态:
      • 输出示例:
  master    abc1234 [origin/master: ahead 2, behind 3] New feature added
  dev       def5678 [origin/dev: behind 1] Bug fixes

      • ahead:本地分支比远程分支多的提交数。
      • behind:本地分支比远程分支少的提交数。
    • 总结
      • 查看修改内容:用 git fetchgit diff
      • 查看提交记录:用 git log
      • 检查同步状态:用 git statusgit branch -vv

3.5. 删除远程分支(git push origin --delete <分支名>

  • 基本原理
    • 远程分支实际上是一个指针,指向仓库中某个提交的引用。
    • 删除远程分支只是移除这个指针,数据会在 Git 服务器上保留一段时间,直到垃圾回收(Garbage Collection,GC)运行。
  • 注意事项
    1. 本地分支保留:该命令只删除远程分支,本地分支仍然存在。
    2. 恢复机制
      • 即使远程分支被删除,其提交记录暂时不会丢失,可以通过 git reflog 找回。
      • 删除是逻辑操作,垃圾回收前数据不会立刻消失。
  • 检查分支状态
    • 使用 git branch -vv 检查本地分支与远程分支的关系,提前确认哪些分支已经同步。

3.6. ⭐远程分支总结

  1. 远程分支概念
    • 远程分支是远程仓库的状态镜像,保存在本地以 <remote>/<branch> 形式表示,如 origin/master
    • 使用 git fetch 更新本地的远程分支状态,但不会修改工作区。
  1. 查看远程分支
    • git ls-remote <remote>:查看远程仓库的所有引用。
    • git remote show <remote>:查看远程分支详细信息。
  1. 推送与拉取
    • 推送git push <remote> <branch> 将本地分支推送到远程分支。
    • 拉取git pull 等效于 git fetch + git merge
    • 建议显式执行 git fetchgit merge 以避免 git pull 的混淆。
  1. 创建跟踪分支
    • git checkout -b <local-branch> <remote>/<branch>:从远程分支创建本地分支并建立跟踪关系。
    • git branch -u <remote>/<branch>:为已有本地分支设置上游分支。
  1. 查看分支状态
    • git branch -vv:查看本地分支与远程分支的跟踪关系及领先/落后状态。
  1. 删除远程分支
    • git push <remote> --delete <branch>:从远程仓库删除分支。

最佳实践

  • 多用 fetch 少用 pull:确保操作的可控性。
  • 定期检查跟踪状态:通过 git fetchgit branch -vv 保持分支状态最新。
  • 推送前检查:确认要推送的内容与远程分支一致,避免冲突。

目录
相关文章
|
13小时前
|
安全 开发工具 git
图解Git——分支管理《Pro Git》
分支管理是 Git 中的重要机制,支持并行开发和清晰的工作流。常用命令包括:`git branch` 列出所有分支,`git branch -v` 查看最后一次提交,`git branch --merged` 和 `git branch --no-merged` 分别查看已合并和未合并的分支。创建新分支用 `git branch &lt;branch-name&gt;`,删除分支用 `git branch -d`(已合并)或 `-D`(强制删除)。建议定期清理已完成任务的分支,保持代码库整洁,并使用有意义的分支命名规范。注意强制删除未合并分支时可能丢失数据。
13 0
|
13小时前
|
网络安全 Apache 开发工具
图解Git——服务器上的Git《Pro Git》
Git 远程仓库及通信协议简介:远程仓库为团队协作提供平台,支持共享代码。常见形式为裸仓库,仅保存 Git 元数据。Git 支持多种协议,包括本地协议(适合局域网)、HTTP/HTTPS(推荐智能 HTTP,安全易用)、SSH(企业内部协作首选)和 Git 协议(高效只读访问)。选择协议需根据协作需求、安全性和配置难度权衡。此外,搭建 Git 服务器涉及创建裸仓库、上传至服务器、初始化共享仓库等步骤。生成 SSH 公钥、配置服务器及使用 GitWeb 或 GitLab 等工具可进一步增强功能。第三方托管服务如 GitHub 提供便捷的托管选项,适合快速启动和开源项目。总结而言,自行运行服务器提
11 1
|
13小时前
|
自然语言处理 开发工具 git
图解Git——变基《Pro Git》
变基(rebase)是Git中用于将一系列提交“重新播放”到另一个分支上的操作,使提交历史更加线性整洁。其基本操作为`git rebase &lt;目标分支&gt;`,可将当前分支的修改基于目标分支重新应用;复杂场景下使用`git rebase --onto &lt;新基底&gt; &lt;旧基底&gt; &lt;分支&gt;`,将特定提交从旧基底移动到新基底。
11 1
|
13小时前
|
开发工具 git 开发者
图解Git——分布式Git《Pro Git》
分布式工作流程主要分为三种模式:集中式工作流、集成管理者工作流和主管与副主管工作流。集中式工作流中,所有开发者同步同一个中央仓库,通过拉取和提交协作;集成管理者工作流中,开发者拥有自己的仓库,通过 `fork` 和请求合并进行协作;主管与副主管工作流适用于大型项目,由主管最终合并代码,副主管负责各自模块。贡献代码时,需考虑活跃贡献者数量、工作流程、提交权限等因素,确保代码合并成功并遵循提交准则。
11 1
|
Java Unix Linux
Git学习
Git学习
82 0
YI
|
安全 IDE Java
Git学习总结(上)
以前在学校提交作业时使用过Git这个工具,感觉自己的使用没有发挥出它的全部优势,所以最近利用假期时间认真学习了一下Git。Git的分布式特性和回滚、分支等操作十分实用,特此记录下Git学习过程。
YI
104 1
YI
|
Ubuntu 开发工具 git
Git学习总结(下)
以前在学校提交作业时使用过Git这个工具,感觉自己的使用没有发挥出它的全部优势,所以最近利用假期时间认真学习了一下Git。Git的分布式特性和回滚、分支等操作十分实用,特此记录下Git学习过程。
YI
64 0
|
Shell 网络安全 开发工具
|
开发工具 git 索引
Git学习(二)
Git学习(二)
173 0
Git学习(二)
|
程序员 开发工具 git