013、推送与拉取:git push与git pull的协作流程

013、推送与拉取:git push与git pull的协作流程

上周排查一个线上问题,发现测试环境代码和仓库主干差了三个提交。问了一圈,原来是有同事本地改了代码直接下班走人,既没推也没拉。团队协作里这种事儿太常见了------你以为同步了,其实各自为政。今天咱们就掰扯清楚 git pushgit pull 这对兄弟到底该怎么用。

先搞明白推送是往哪儿推

很多人以为 git push 就是把代码"传到网上",其实不对。推送的本质是把本地分支的提交记录同步到远程仓库的对应分支。你本地仓库里那些 .git 目录下的对象,通过 push 操作在远程仓库里复制了一份。

bash 复制代码
# 最常用的推送命令
git push origin main

# 这个命令拆开看:
# origin 是你给远程仓库起的别名(默认就有)
# main 是你要推送的本地分支名
# 意思是:把本地 main 分支推送到 origin 仓库的 main 分支

这里有个坑:如果远程分支名和本地不一样,得明确指定。比如你本地分支叫 dev,远程想推送到 main,得用 git push origin dev:main。别直接 git push 就完事儿,容易推错分支。

拉取之前先看看别人动了什么

直接 git pull 是新手最容易翻车的操作。特别是团队协作时,你不清楚上游有什么改动,一拉可能就把冲突带进来了,而且合并得莫名其妙。

bash 复制代码
# 先看看远程有啥新东西
git fetch origin

# 查看远程分支更新情况
git log origin/main --oneline

# 确认没问题再合并
git merge origin/main

# 上面两条命令合起来就是 git pull
# 但分开操作更安全,心里有数

我习惯先 fetch 再 diff,看看别人改了哪些文件。有时候同事提交了大型配置文件或者生成文件,我得先决定要不要这些改动,再决定怎么合并。

推送被拒绝?多半是历史分叉了

当你兴冲冲地 git push,却看到 "rejected" 错误时,别慌。这通常是因为远程分支有你没有的新提交,Git 怕你覆盖别人的工作。

bash 复制代码
# 典型错误信息
! [rejected]        main -> main (non-fast-forward)

# 意思是远程分支比你本地领先了
# 这时候别强制推(-f),除非你确定要覆盖
# 正确做法是先拉取合并
git pull --rebase origin main
git push origin main

--rebase 选项可以把你的提交"挪到"远程最新提交之后,保持线性历史。不过要注意,如果已经推送过的提交就别 rebase 了,会扰乱团队其他人的历史记录。

配置上游分支省点力气

每次 push 都要打 origin main 挺烦的。其实可以设置上游关联:

bash 复制代码
# 推送同时设置上游
git push -u origin main

# 之后直接 git push 就行
# Git 知道你要推到哪里

git branch -vv 能看到本地分支跟踪的远程分支。这个设置特别适合长期开发的功能分支,一劳永逸。

个人经验:养成推送前的好习惯

我在团队里定了个规矩:推送前必须做三件事。一是 git status 看看有没有不该提交的文件,二是 git diff 确认改动内容,三是 git fetch 检查远程动态。这套流程坚持下来,能避免 80% 的合并冲突。

还有个细节:提交信息写清楚。别用"修复""更新"这种模糊描述,至少说明改了哪个模块、为什么改。半年后回看历史记录,你会感谢自己的。

最后说说 git pull 的两种方式:git pull 默认是 fetch + merge,会生成合并提交;git pull --rebasefetch + rebase,保持线性历史。团队项目建议统一用同一种方式,不然历史记录会很难看。

协作开发就像多人共舞,push 和 pull 是基本步法。步子乱了不怕,Git 能帮你找回节奏,但前提是你得听懂它的提示。下次推送前,多看一眼终端里的信息,那都是 Git 在跟你说话。

相关推荐
武子康13 小时前
调查研究-197 FAISS vs Elasticsearch 全面对比:从向量检索、全文搜索到 RAG 选型指南
人工智能·elasticsearch·agent
大大大大晴天13 小时前
Hudi技术内幕:深入解析Index索引机制
大数据
阿里云大数据AI技术14 小时前
Flink Forward Asia 2026 深圳启幕:Agentic Streaming for AI,开启实时智能新范式
大数据·flink
SelectDB1 天前
阶跃星辰基于 SelectDB 构建 PB 级 Agent 可观测平台
大数据·数据库·aigc
Elasticsearch2 天前
Elasticsearch ES|QL:现已支持视图、子查询和读取时模式定义
elasticsearch
嘻嘻仙人2 天前
Ubuntu中 git上传自己的项目和二次上传一般流程
git·github
Patrick_Wilson2 天前
Squash Merge 的血缘陷阱:为什么删掉的代码又活了过来
前端·git·程序员
沉浸学习的匿名网友2 天前
什么是 .gitignore?为什么每个 Git 项目几乎都离不开它?
前端·git
深海鱼在掘金3 天前
Git 完全指南 —— 第3章:理解工作区、暂存区、版本库三个核心
git
江华森3 天前
Git 基础筑基:从原理到团队协作的全栈实战
git