2

我有一个 Centos 7 虚拟机(VirtualBox 来宾)作为我的 svn 服务器,已经配置了 svn -- mod_dav_svn 并且一切正常:可以签出和提交。问题是当添加一个预提交钩子然后尝试从 Windows 机器(VirtualBox 主机)提交时,TortoiseSVN 失败并出现此错误

提交被 pre-commit 钩子(退出代码 255)阻止,没有输出。

从我得到的httpd日志

[客户端 xx.xx.xx.xxx:57] 无法将资源“/svn/testrepo/!svn/txn/5-2f”合并到“/svn/testrepo/trunk”中。[500, #0]

所有权限都设置正确,我什至尝试了 777,除非我删除钩子,否则它不起作用。

这是我设置的参考: http ://www.unixmen.com/install-subversion-centos-7/

我想知道我的 10-subversion.conf 文件中是否缺少某些内容...

我正在使用默认的预提交,它已经设置为可执行文件,并且所有者是 apache 用户。我做的另一个测试是删除预提交脚本中的所有代码,只留下“exit 0”指令。

这就是我的 10-subversion.conf 文件的样子:

    LoadModule dav_svn_module     modules/mod_dav_svn.so
    LoadModule authz_svn_module   modules/mod_authz_svn.so
    LoadModule dontdothat_module  modules/mod_dontdothat.so

    <Location /svn>
       DAV svn
       SVNParentPath /var/www/svn
       AuthType Basic
       AuthName "Subversion repositories"
       AuthUserFile /etc/svn-auth-users
       Require valid-user
    </Location>
CustomLog logs/svn_logfile "%t %u %{SVN-ACTION}e" env=SVN-ACTION
4

2 回答 2

6

终于有办法解决这个问题了。根本原因是 SELinux 不允许通过 httpd 服务执行预提交脚本。我通过运行这条线来摆脱它

chcon -t httpd_exec_t pre-commit

感谢大家!我希望这对其他人有帮助。

于 2015-02-02T19:34:37.617 回答
2

你能发布你的预提交脚本吗?如果没有,请将以下内容添加到您的“.sh”脚本中。

set -xv

在之后的行

#!/bin/bash

最终看起来:

#!/bin/bash
set -xv

如果这没有为您提供更多日志记录,请将输出重定向到脚本中的文件。所以你可以调试你的脚本。

您还可以增加 apache 中的日志记录。检查这个 http://svnbook.red-bean.com/en/1.6/svn.serverconfig.httpd.html#svn.serverconfig.httpd.extra.logging

因此,您将获得一个仅用于 SVN 的文件,并且您也可以使用日志级别进行播放。

我个人会先尝试,因为更容易更改脚本。

(对于您的下一个问题,请更具体)

于 2015-01-31T09:34:23.110 回答