redhat – svnserve似乎以root身份写文件.如何通过svnserve和apache访问同一个存储库?

目的是使用svnserve和apache / webdav访问设置subversion.

当用户通过http / apache提交时,文件被写入文件系统并属于apache用户.

当用户通过svn / svnserve提交​​时,文件将写入文件系统并属于root用户.

我尝试将apache设置为svnserve用户而没有改进:

cat /pathto/repo/conf/passwd
[users]
apache = XxXxXxX

 cat /pathto/repo/conf/svnserve.conf
[general]
anon-access = none
auth-access = write
password-db = passwd


[sasl]
use-sasl = false

svn: Commit failed (details follow):
svn: Can't move '/pathto/repo/db/txn-protorevs/1091-ux.rev' 
to '/pathto/repo/db/revs/1/1092': Permission denied

确实,root是目录的所有者,我想要apache.

ls -ld /pathto/repo/db/revs/1/
drwxr-s--- 2 root svn 4096 Jul 17 15:25 /pathto/repo/db/revs/1/

现在我使用以下解决方法:

chown -R apache /pathto/repo/db/

有没有人有一个干净的解决方案来运行svnserve?

更新1:svnserve作为独立服务运行

更新2:这是/ etc / sysconfig / svnserve内容:

OPTIONS="--threads --root /pathto "

更新3:我同意JvO:使用http / apache / webdav作为唯一的访问系统会更简单.不幸的是,第三方软件只有svn://绑定而没有http://绑定.

更新4:修改svnserve init脚本应该有效,但有人有另一个想法吗?

更新5:添加赏金:寻找优雅的解决方法

解决方法

显然,您的svnserve进程以root身份运行.因此,更改配置以将该进程作为某个非特权用户运行(不清楚svnserve是如何从您的描述中启动的;可能是xinetd或其他内容).

安全方面,IMO的最佳方法是将apache和snvserve用户添加到公共组(如’svn’)并将存储库的权限更改为drwxrws —(即组权限为’sticky’ )

相关文章

linux常用进程通信方式包括管道(pipe)、有名管道(FIFO)、...
Linux性能观测工具按类别可分为系统级别和进程级别,系统级别...
本文详细介绍了curl命令基础和高级用法,包括跳过https的证书...
本文包含作者工作中常用到的一些命令,用于诊断网络、磁盘占满...
linux的平均负载表示运行态和就绪态及不可中断状态(正在io)的...
CPU上下文频繁切换会导致系统性能下降,切换分为进程切换、线...