当前位置: 首页 > news >正文

git pull

文章目录

  • 1.简介
  • 2.格式
  • 3.选项
  • 4.示例
    • 4.1 基础用法
    • 4.2 使用 rebase 代替 merge(推荐)
    • 4.3 只允许快进
    • 4.4 自动暂存本地修改
    • 4.5 拉取指定分支到本地指定分支
  • 5. 注意
    • 5.1 `git pull` vs `git fetch`
    • 5.2 解决 `git pull` 产生的合并冲突
    • 5.3 避免“丑的”合并提交
    • 5.4 常用别名设置
  • 6. 小结
  • 参考文献

1.简介

git pull是 Git 中最常用的命令之一,用于从远程仓库拉取最新代码并合并到当前分支

它实际上是两个命令的组合:

gitfetch +gitmerge
  • git fetch:从远程下载最新代码(不自动合并)
  • git merge:将下载的代码合并到当前分支

⚠️git pull会自动执行合并,可能会产生合并提交。如果希望避免自动合并,可以使用git pull --rebase

2.格式

gitpull[<options>][<repository>[<refspec>]]

repository 为远程仓库名称,指定从哪个远程仓库拉取,默认为 origin。

refspec 为引用规格,用于指定拉取哪些引用(分支/标签),以及如何映射到本地引用。它的格式灵活,可以是以下几种形式:

形式示例说明
<分支名>main拉取远程分支,并合并到当前分支
<分支名>:<本地分支名>main:feature拉取远程分支,并合并到指定的本地分支
+<分支名>+main强制拉取(允许非快进更新)
<标签名>v1.0.0拉取指定标签
refs/heads/*:refs/remotes/origin/*(默认)拉取所有分支到远程跟踪分支

3.选项

-r,--rebase使用 rebase 方式合并,而不是 merge(保持线性历史) --ff-only 只允许快进合并,如果不能快进则报错 --no-ff 强制创建合并提交(即使可以快进)--autostash拉取前自动暂存本地未提交的修改,拉取后自动恢复 --no-commit 拉取并合并,但不自动提交 -v,--verbose显示详细信息--all拉取所有远程分支的更新

4.示例

4.1 基础用法

# 拉取 origin 远程的 main 分支,并合并到当前分支gitpull origin main# 如果当前分支已关联远程分支,直接执行gitpull

4.2 使用 rebase 代替 merge(推荐)

# 拉取并变基,保持线性历史gitpull--rebaseorigin main

git pull --rebase=git fetch+git rebase,而不是默认的git fetch + git merge

使用--reabase选项可以使项目提交历史变成直线,没有分叉,非常整洁。

简单来说:它把你本地独有的提交“挪”到远程最新提交的后面,而不是创建一个合并提交来“汇合”,即可以消除Merge branch 'main' of <repository path>这种 commit 记录。建议使用 -r(–rebase)选项。

4.3 只允许快进

# 只能快进,否则报错(避免意外创建合并提交)gitpull --ff-only origin main

4.4 自动暂存本地修改

# 拉取前自动 stash,拉取后自动 stash popgitpull--autostashorigin main

4.5 拉取指定分支到本地指定分支

# 将远程 dev 分支拉取到本地的 feature 分支gitpull origin dev:feature

5. 注意

5.1git pullvsgit fetch

命令行为适用场景
git fetch只下载,不合并先查看远程更新,再决定是否合并
git pull下载 + 自动合并确信没有冲突,快速同步

5.2 解决git pull产生的合并冲突

# 拉取时产生冲突gitpull origin main# CONFLICT in main.go# 手动解决冲突后gitadd.gitcommit-m"Merge remote-tracking branch 'origin/main'"# 或者放弃合并gitmerge--abort

5.3 避免“丑的”合并提交

# 推荐:使用 rebase 保持线性历史gitpull--rebaseorigin main# 或者设置为默认行为gitconfig--globalpull.rebasetrue

5.4 常用别名设置

gitconfig--globalalias.pu"pull --rebase"gitconfig--globalalias.puf"pull --rebase --autostash"# 使用别名gitpu origin maingitpuf origin main

6. 小结

需求命令说明
普通拉取(默认)git pull origin main下载 + 合并(可能产生合并提交)
拉取并变基(推荐)git pull --rebase origin main保持线性历史
只允许快进git pull --ff-only origin main不能快进时报错,避免意外合并
自动暂存本地修改git pull --autostash origin main拉取前自动 stash,拉取后自动恢复
查看远程更新(不合并)git fetch origin先看再决定

一句话总结git pull=git fetch+git merge,是同步远程代码最常用的命令。推荐团队统一使用git pull --rebase保持线性历史,避免出现“丑的”合并提交。如果有本地未提交的修改,可以配合--autostash使用。


参考文献

Git - git-pull Documentation

http://www.zskr.cn/news/1493432.html

相关文章:

  • 每日热门skill:12万人都在用的Agent Browser:给AI装上“手脚“后,我的工作效率翻了3倍
  • 【深度解析】无人值守称重系统:核心原理与工业应用 - 速递信息
  • LPC2114/2124数据手册深度解析:ARM7 MCU选型、功耗管理与外设开发实战
  • i.MX 7ULP通信接口时序设计:I2C、SPI、USB关键参数与调试实践
  • 如何高效使用B站API:Python开发者终极实战指南
  • LinkSwift:八大主流网盘直链解析工具完整指南
  • ViGEmBus:Windows内核级游戏控制器模拟驱动深度解析与实战指南
  • 高效整理Chrome书签的树形管理插件:Neat Bookmarks深度评测
  • UrBackup客户端配置全攻略:10个关键设置优化备份性能与安全
  • Beyond Compare 5 终极激活指南:开源密钥生成工具完整教程
  • 深入解析恩智浦K60微控制器:从Cortex-M4内核到外设实战应用
  • XUnity Auto Translator:三步快速安装,让外语游戏秒变中文的终极指南
  • G-Helper终极方案:AMD CPU降压深度解析与实战指南
  • ClickHouse ReplicatedMergeTree:多副本架构与数据一致性保障
  • 如何在5分钟内将Chrome变成专业级Markdown阅读器?markdownReader插件完全指南
  • LPC13xx电气特性解析:从参数到低功耗与接口设计实战
  • 2026年无锡电动推杆源头厂家与全国防爆电动执行机构深度选型指南 - 企业名录优选推荐
  • i.MX RT1064硬件设计实战:电气特性与接口时序深度解析
  • 上海交通大学中银科技金融学院技术转移硕士2026详解:全日制新增、选拔改革与五力培养全解 - 领先技术探路人
  • 如何永久保存微信聊天记录:三步实现数据备份与情感珍藏
  • 嵌入式硬件设计基石:从NXP K20数据手册电气特性到稳定系统实践
  • League Akari:英雄联盟玩家的智能一站式游戏伴侣解决方案
  • 2026 新乡防水补漏公司 TOP5 口碑榜:卫生间免砸砖修复、楼顶外墙漏水检修、瓷砖空鼓修补全维度测评 - 泛家庭维修
  • 小鱼消消乐微信小游戏完整可运行源码,含调试配置与本地预览入口
  • 财税AI软件推荐:亿企赢与主流平台横向对比,企业怎么选更稳? - 新闻快传
  • APA第7版参考文献格式终极指南:3分钟快速上手Word引用管理
  • 前端技术10-前后端分离太麻烦?Nuxt 3让你一套代码搞定全栈:SSR + API路由 + 自动导入
  • 2026保姆级教程:制作小二寸照片用什么APP?附标准尺寸参数详解 - 办公小帮手
  • GPIO的使用
  • 2026年山西企业私域转化系统深度测评:精准定向推广vs全网营销矩阵 - 优质企业观察收录