GitHub -- 上传出错解决方案汇总

前言

  • 记录时间:2020.6.19
  • 内容:更新一下上传过程中主要会出现的问题,原因不外乎更改了本地文件与仓库文件不一致,上传时候系统就不知道如何处置你仓库里和本地名字一样的代码文件,是覆盖还是咋咋滴?有引用很多博主的,然鹅界面重启之后就找不到了。。(侵删)
  • 备注:问题2和问题3我还没遇上,等遇上试了再来更新,码住就完事了!

问题1

上传步骤:
git add .
git commit -m “提示消息”
git push origin master

出错:
! [rejected] master -> master (fetch first) error: failed to push some refs to ' 。。。'

解决1:
其他方法。(该方法于我无效,说rebase找不到)
出现这个问题是因为github中的README.md文件不在本地代码目录中,可以通过如下命令进行代码合并
git pull --rebase origin master
GitHub -- 上传出错解决方案汇总
解决2:
温柔办法。(我没试过这个方法。)
通过git pull 先将本地库更新到与远程库一致的版本,但要注意本地库后来做的修改可能被覆盖,最好使用git fetch(不会自动合并),查看更新情况再有选择合并,或者先将本地库修改过的文件备份,git pull后再重新修改;再运行git push即可成功。

解决3:
暴力方法。不适合团队合作,但非常适合自己仓库里大改动,几乎重构修改又不想保留原版的情况。(我用的这个,很快搞定了)
git提供了一种强制上传的方式:git push -f ,它会忽略版本不一致等问题,强制将本地库上传的远程库,但是一定要谨慎使用,因为-f会用本地库覆盖掉远程库,如果远程库上有重要更新,或者有其他同伴做的修改,也都会被覆盖,所以一定要在确定无严重后果的前提下使用此操作。

GitHub -- 上传出错解决方案汇总

问题2

! [remote rejected] master -> master (pre-receive hook declined)

在推送代码时报错如上,网上搜到的方法说是项目的setting中master是受保护的项目,所以开发者无法推送,解决方法是修改protected的设置,或者新建一个分支,推送到自己的分支上

解决办法的文章:https://www.cnblogs.com/cppeterpan/p/7289266.html

问题3

上传步骤:
git add .
git push origin master

问题 :
everything up-to-date

原因:
git提交改动到缓存,要push的时候不会将本地所有的分支都push掉,所以出现这个问题。那么我们就需要新建分支提交改动然后合并分支。

解决:
1.先创建一个新的分支提交改动
$ git branch newbranch

2.检查这条命令是否创建成功
$ git branch
这时终端会输出:
newbranch
*master
这样就创建成功了,前面的*代表的是当前你所在的工作分支,接下来就要切换工作分支。

3.git checkout newbranch

4.然后将你的改动提交到新的分支上
$ git add .
$ git commit -m "提示消息"
此时可以$ git status 检查下提交情况。如果提交成功,我们接下来就要回主分支了,$ git checkout master

5.我们将新分支提交的改动合并到主分支上
$ git merge newbranch
合并分支可能产生冲突这是正常的,虽然我们这是新建的分支不会产生冲突,但还是在这里记录下。
可以用$ git diff来查看产生冲突的文件,然后做对应的修改再提交一次就可以了。

6.我们的问题解决了,接下来就可以push代码了
$ git push -u origin master

7.最后,新建分支的朋友别忘了删除分支
$ git branch -D newbranch
如果想保留分支只是想删除已经合并的部分只要把大写的D改成小写的d就行了。

总结,我在上传的过程中大概就遇到了这几个主要问题,网上搜了很多解决方案,发现即使遇到的问题一样,解决方法也可能不适用自己。记录一下,以后再看有没有其他解决方法和问题。

参考:https://blog.****.net/weixin_43264399/article/details/87350219