一、背景描述
最近公司的版本管理工具,统一由 SVN 改为 GIT ,今天新分配的 GIT 账号和新项目,拉下来代码发现 push 不上去,以为是自己本地仓库 GIT 账号和新分配的冲突原因呢,我最后统一改成一样的还是 push 失败。
注意:以下是我从 GIT 的 master 仓库拉取的,然后又从本地提交代码至 master 仓库。然后才出现的这个问题。
remote: GitLab: You are not allowed to push code to protected branches on this project.
Push master to origin/master was rejected by remote
然后在网上搜索有的说是 按照以下命令(打开你要上传代码的文件夹位置鼠标右键git Bash Here然后直接下面两行命令解决问题)就可以了。然而,我试了试,还是不行哦。
git pull origin master --allow-unrelated-histories
git push -u origin master -f
不过这个命令一定要慎用,git push -u origin master -f 是强制推送的意思。强制推送 要慎用!慎用!慎用!重要的事情说三遍!这会让别人提交的代码被覆盖!!!
可以看到,我使用以上命令,依然解决不了问题。
二、原因分析
最后经过与运维同事探讨,原来是他在主分支上添加了限制权限,不允许直接提交到主分支导致的。原因是因为权限不够,master 分支被保护了,所以才会导致这个问题的出现。
三、解决方案
在 GIT 仓库中,重新创建一个分支:
然后 从这个新创建的分支上 pull 代码,编辑过后,然后 push 到这个 新创建的分支上即可。
完结!