我已经在虚拟机上运行了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的,但类似的错误也会发生在github上,这取决于它是如何设置的(通常是github Enterprise)。

您需要熟悉以下概念:

pre-receive钩子 组织人 人则

webhook比其他两个项目更容易理解。

预接收钩子

是运行在GitHub企业服务器上的脚本吗 执行政策。当发生推送时,每个脚本在一个 孤立的 环境 以确定是否接受或拒绝推送。

组织人:

Webhook事件也从你的存储库发送到你的“组织Webhook”。更多信息。

这些都设置在你的github企业。它们是特定于github企业版本的。 由于您的访问限制(开发人员、维护人员、管理员等),您可能没有可见性。

其他回答

如果你正面临这样的问题

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

这是因为master是受保护的,你可以做2步

要移除保护,请遵循以下步骤-

进入项目设置。 单击Repository选项卡。 打开受保护的分支。 找到你的主分支并单击Unprotect。

否则

我们可以从主分支切换到主分支

Git checkout -b main git分支-D master Git push heroku main

黑客快乐! !

您可能没有开发人员访问项目或主分支的权限。你需要开发权限来推动新工作。

新的工作意味着新的分支和提交。

对我来说,发生这种情况是因为之前的未决意见不符合某些标准。经过下面的命令,它为我工作 git重置——硬提交 (成功提交的commit id先于不成功提交的commit id)

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

转到项目设置—> Hooks—>(下)预接收Hooks

禁用 Cp要求在提交时引用问题