我已经在虚拟机上运行了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总是空的。也许问题就在这里……如果是这样,请给我建议如何解决。谢谢


当前回答

GitLab默认将主分支标记为受保护(请参阅https://about.gitlab.com/2014/11/26/keeping-your-code-protected/ why中的保护代码部分)。如果你的情况是这样,那么下面的方法会有所帮助:

打开你的项目> Settings > Repository,进入“Protected branches”,在列表中找到“master”分支,然后点击“Unprotect”再试一次。

通过https://gitlab.com/gitlab-com/support-forum/issues/40

8.11及以上版本的操作指南请访问:https://docs.gitlab.com/ee/user/project/protected_branches.html#restricting-push-and-merge-access-to-certain-users

其他回答

我经历过这种情况,只是因为AWS破损。

要排除这种情况,只需检查消息是否包含类似的内容

<head><title>504网关</title></head>

所以,如果你之前没有做过任何可疑的事情,只是开始看到这个-这可能只是服务器超时。

GitLab默认将主分支标记为受保护(请参阅https://about.gitlab.com/2014/11/26/keeping-your-code-protected/ why中的保护代码部分)。如果你的情况是这样,那么下面的方法会有所帮助:

打开你的项目> Settings > Repository,进入“Protected branches”,在列表中找到“master”分支,然后点击“Unprotect”再试一次。

通过https://gitlab.com/gitlab-com/support-forum/issues/40

8.11及以上版本的操作指南请访问:https://docs.gitlab.com/ee/user/project/protected_branches.html#restricting-push-and-merge-access-to-certain-users

似乎问题出在一些服务上,比如sidekiq。执行sudo -u git -H bundle exec rake gitlab:check RAILS_ENV=production将输出config中的所有问题。

请检查JIRA状态是否在“开发中”。 对我来说,不是,当我把jira的状态改为“开发中”时,它对我有用。

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