我已经在虚拟机上运行了gitlabhq rails服务器,遵循本教程https://github.com/gitlabhq/gitlab-recipes/blob/master/install/centos/README.md中的1-6步,并启动rails服务器,执行命令sudo -u git -H bundle exec rails s -e production。之后,我创建了用户,使用管理工具,并在此用户下创建了新项目。然后,我试图像往常一样将现有项目推到这个回购。但在最后一步,git push origin master失败,并出现错误

[远程拒绝]master -> master(预接收钩子拒绝)

额外的信息:

1)我还没有通过电子邮件激活链接激活用户(项目所有者),因为我还没有在服务器端配置post服务,我没有找到如何在本手册中做到这一点的说明。

2) Gitlab服务器生成提示如何推送项目到repo,没有repositories/ in路径。我的意思是它生成git@mygitlabhost:user/repo。Git代替git@mygitlabhost:repositories/user/repo。Git是正确的。

3)当我试图调试它时,我在服务器上的repo中打开了预接收脚本,并尝试输出变量(有3个):refs = ARGF。read, key_id = ENV['GL_ID'] and repo_path = Dir。PWD和发现,key_id总是空的。也许问题就在这里……如果是这样,请给我建议如何解决。谢谢


当前回答

重命名项目并复制所有更改。


我几乎试过了这一页上的所有答案。

最后,我这样做来解决这个问题:

将项目重命名为project-tmp 再次将项目克隆到项目 手动将所有更改从project-tmp移动到project(显然不是复制。git文件夹)。 Git添加。 git commit -m 'Blah Blah ' git推

那工作!


为什么会这样?

我的理论是,在某些提交(或某些东西)中,有一个糟糕的设置把它搞砸了。

转到 LFS

我做的另一件事是,我设置了git lfs。我不确定这是否重要。

其他回答

我最近在Gitlab上遇到了这个问题,上面的解决方案都不适合我。

最后,我意识到公钥是由我的同事部署到存储库上的,他已经离开了公司,他的帐户在几周后被禁用了。这导致他使用的钥匙无法使用,即使这不是他的个人钥匙。

我删除了密钥,重新上传了相同的密钥,它起作用了。永久解决方案是创建一个服务帐户并使用该帐户上传密钥。

引用自Gitlab文档。

所有部署密钥都关联到一个帐户。由于帐户的权限可能会更改,这可能会导致正在工作的部署密钥突然无法推送到受保护分支的情况。

我已经按照heroku日志img https://devcenter.heroku.com/articles/buildpacks#detection-failure的指示(使用cmd: heroku日志->显示您的错误) 然后执行cmd: "heroku buildpacks:clear"。最后,它对我有用!

请尝试:

git push -u origin master

如果你仍然不能成功地推送,创建一个新分支或选择另一个分支并推送新分支

这是因为主分支受到保护,以下是清除此错误的步骤。

在你的主分支中创建一个分支git checkout -b new-branch-name 推送新的分支git Push——set-upstream origin new-branch-name 现在远程地将分支合并到主分支。 一旦合并,重置本地主分支git重置-soft HEAD~1 最后git拉

我通过在.git/config中将远程“origin”url从http更改为git协议来解决这个问题