当前位置 : 祺云SEO > 服务器运维>

git如何提交到远程和本地?git push命令详解

时间:2026-06-30 来源:祺云SEO
Git提交代码&拉取代码&冲突解决
程序员郑清
2万312-原视频地址

本地仓库与远程仓库的本质差异

要掌握Git提交,首先得明白这两个“仓库”到底存的是什么,以及它们各自承担的角色。

本地仓库:你的个人工作区

本地仓库是你日常开发的主战场,它存储着你当前项目的所有版本历史、分支信息以及暂存区状态,当你执行gitaddgitcommit时,你实际上是在本地的数据库里打了一个“快照”,这个快照只存在于你的硬盘上,其他同事、服务器甚至你的另一台电脑都看不到。

业内专家指出,本地提交的主要目的是保护代码状态,当你完成了一个功能模块但还没调试完美时,先提交到本地,这样即使后续修改出错,也能随时回滚到之前的稳定状态,这是一种安全机制,而非协作机制。

远程仓库:团队的共享中心

远程仓库通常托管在GitHub、GitLab、Gitee或公司内部的Git服务器(如GitLabCE/EE)上,它是一个裸仓库(barerepository),不包含工作目录,只存储版本数据,它的作用是作为“中央服务器”,供团队成员拉取最新代码和推送自己的成果。

如果把本地仓库比作个人的日记本,远程仓库就是班级的公告栏,你写完日记(本地提交)后,需要把精华部分贴到公告栏(推送到远程),大家才能看到并在此基础上继续创作。

两者同步的关键:Push与Pull

本地和远程并非自动同步,需要通过特定的命令建立连接。

  • Push(推送):将本地的新提交发送到远程。
  • Pull(拉取):从远程获取最新提交并合并到本地。

标准操作流程与命令解析

理清概念后,我们进入实操环节,一个完整的“提交到远程”流程通常包含四个步骤,为了让大家更直观地理解,我们对比一下不同场景下的操作路径。

首次初始化与关联远程

如果你刚开始一个新项目,或者克隆了一个新仓库,首先需要建立本地与远程的联系。

  1. 初始化本地仓库: gitinit
  2. 添加远程地址别名(通常命名为origin): gitremoteaddorigin<远程仓库URL>

    这里的URL可以是HTTPS地址,也可以是SSH地址,对于追求安全和高频操作的开发者,业内共识认为使用SSH密钥认证能显著提升连接稳定性并避免频繁输入密码。

日常提交三部曲

这是最高频的操作场景,假设你修改了几个文件,想要保存进度并同步到团队。

  1. 查看状态

    gitstatus

    这一步至关重要,它能告诉你哪些文件被修改了,哪些是未跟踪的新文件。

  2. 添加到暂存区

    gitadd.

    或者指定具体文件:gitaddfilename.txt,这一步是将文件的变化标记为“准备提交”,但尚未真正写入历史记录。

  3. 提交到本地仓库

    gitcommit-m"描述你的修改内容"

    代码已经安全地保存在本地历史中了。

  4. 推送到远程仓库

    gitpush-uoriginmain

    注意:-u参数用于设置上游分支,之后再次推送只需输入gitpush即可,这里的main是默认分支名,部分项目可能使用master,请根据实际仓库设置调整。

处理冲突与合并

在多人协作中,直接推送经常会遇到阻碍,最常见的是“推送被拒绝”或“合并冲突”。

  • 场景描述:当你尝试推送时,如果远程仓库有新的提交,而你的本地版本落后,Git会阻止推送以防止覆盖他人的代码。
  • 解决方案
    1. 先拉取远程更新:gitpulloriginmain
    2. 如果有冲突,手动编辑文件解决冲突标记(<<<<<<>>>>>>)。
    3. 重新添加并提交:gitadd.->gitcommit-m"解决冲突"
    4. 再次推送:gitpushoriginmain

常见误区与最佳实践

很多新手在操作Git时容易犯一些低级错误,导致代码丢失或历史混乱,以下是几条基于行业经验的避坑指南。

不要跳过本地提交直接推送

有些开发者觉得麻烦,修改完代码直接gitpush,这是错误的,因为gitpush只能推送已经commit,如果没有本地提交,代码变更不会进入版本控制,一旦误删文件,数据将永久丢失。

小步快跑,频繁提交

与其一天写几百行代码最后提交一次,不如每完成一个小功能就提交一次。

  • 优点:历史清晰,便于回溯;如果出错,容易定位问题代码。
  • 缺点:无明显缺点,除了日志稍多,但现代Git客户端能很好地处理这个问题。

分支管理策略

对于大型项目,直接在主分支(main/master)上开发是高风险行为,建议采用GitFlow或GitHubFlow工作流。

  • 开发分支:如devfeature/login,用于日常开发。
  • 主分支:仅用于存放稳定版本。
  • 合并请求(MR/PR):通过PullRequest或MergeRequest将代码合并到主分支,并进行代码审查(CodeReview)。

Q&A:关于Git提交的常见问题

git提交到远程服务器和本地仓库有什么区别?

本地仓库是版本控制的存储库,负责记录每一次代码变更的历史快照,确保数据在本地可恢复,远程仓库则是分布式的中心节点,负责同步团队代码,实现多人协作,本地提交是私有行为,远程推送是共享行为。

gitpush被拒绝怎么办?

这通常是因为远程仓库有新的提交,导致本地版本落后,此时应先执行gitpull拉取最新代码,解决可能产生的合并冲突后,再重新执行gitpush

如何撤销已经推送到远程的错误提交?

可以使用gitrevert命令生成一个新的提交来抵消之前的错误,这是最安全的做法,因为它保留了历史记录,如果确定该提交从未被他人拉取,也可以使用gitpush--force强制覆盖,但这会破坏团队其他人的历史,需谨慎使用。