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 在跟你说话。

相关推荐
升鲜宝供应链及收银系统源代码服务1 小时前
升鲜宝AI助手 E-R 图与操作说明书(三)---升鲜宝生鲜配送供应链管理系统源代码服务
大数据·人工智能·机器学习·生鲜供应链源代码·供应链源代码出售·生鲜配送源代码服务·门店连锁系统源代码
财经资讯数据_灵砚智能1 小时前
基于全球经济类多源新闻的NLP情感分析与数据可视化(日间)2026年6月5日
大数据·人工智能·python·ai·信息可视化·自然语言处理·灵砚智能
谁似人间西林客1 小时前
数据驱动制造:工业大数据如何重塑智能决策链?
大数据·制造
真上帝的左手1 小时前
19. 大数据- BI - AI 应用1-融合场景解析
大数据·人工智能·ai·bi
梅塔文·欧帕西安卡琼2 小时前
git的底层原理详解
git
待什么青丝2 小时前
【git的摸鱼技巧】之工欲善其事
git·elasticsearch·搜索引擎
小王毕业啦2 小时前
2009-2024年 各国清廉指数CPI(xlsx)
大数据·人工智能·数据挖掘·数据分析·社科数据·实证分析·经管数据
杨某不才2 小时前
内网环境下,使用Docker安装Elasticsearch分词器插件
elasticsearch·docker·jenkins
2601_961194022 小时前
教资科三美术考什么|初中高中美术题型考点和模板资料
leetcode·elasticsearch·职场和发展·蓝桥杯·pat考试·lucene
AIkk863 小时前
班级群学习资料分享指南:工具推荐与实践
大数据·人工智能·html