一次性解决Git远程推送报错问题

  • 这两天在推送 Memory API 项目代码到 Gitee 仓库的过程中,遇到了很多问题
  • 花了整整两天时间,才成功地推送代码成功,下面我将介绍推送代码时的常见报错和解决办法
  • 将文件的修改加入暂存区:

git add .

  • 这一步操作,是将该本地分支内的所有文件都添加至暂存区
  • 将暂存区的文件提交修改到版本库:

git commit -m "提交信息"

  • 注意这里的提交信息不能为空,否则该提交操作会被驳回:

image-20230728143850131

  • 推送代码之前,应该拉取远程分支的代码到本地,同步过后再提交:

git pull origin master

git pull origin master

  • 这时,推送代码可能会报这种错误:

! [rejected] master -> master (fetch first) error: fail to push some refs

  • 说明本地分支的代码与远程分支代码部分文件有冲突,需要将有冲突的文件,一一合并,如此拉取:

git pull --rebase origin master

  • 发生冲突意味着 Git 无法自动决定如何合并代码,这需要我们手动合并文件,解决冲突
  • 如果你不知道要合并哪些文件,可以执行以下命令,提交合并结果:

git rebase --continue

  • 这时,如果还有未合并的冲突文件,就执行以下命令,手动合并:

git add 冲突文件名

  • 完成这步操作,就可以推送代码了

注意

  • 在执行这段代码时:

git pull --rebase origin master

  • 网上有的教程可能会跟你讲,执行以下代码来退出 rebase 过程:

git stash / git reset --hard HEAD

  • 千万不要这样做,这样会放弃提交本地的所有改动,回退到最近的一次提交状态,本地分支也会被远程分支覆盖
  • 正确的做法就是上面提到的,正常合并冲突文件,最后提交
  • 或者如果不想提交本次修改,可以选择退出合并冲突文件,执行以下代码:

git rebase --abort

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值