我刚将我的subversion存储库从旧的FreeBSD服务器移动到使用Apache 2.4的新的Ubuntu 16服务器。我在“sites-available”中配置了一个新站点并重新启动了Apache,这给了我这个错误:
[so:warn] [pid 15619] AH01574:模块dav_module已加载,正在跳过
似乎所有与dav相关的加载模块都不同。我没有看到dav_module加载两次:
# cd /etc/apache2
# grep -rI "LoadModule" * | grep dav
mods-available/dav_fs.load:LoadModule dav_fs_module /usr/lib/apache2/modules/mod_dav_fs.so
mods-available/dav_svn.load:LoadModule dav_svn_module /usr/lib/apache2/modules/mod_dav_svn.so
mods-available/dav.load:LoadModule dav_module /usr/lib/apache2/modules/mod_dav.so
mods-available/dav_lock.load:LoadModule dav_lock_module /usr/lib/apache2/modules/mod_dav_lock.so
除了表单subversion和apache,我安装了这些包:
# apt-get install subversion-tools libapache2-svn
我注意到安装负责加载模块(a2enmod),所以我没有做任何事情。
这是我的虚拟主机配置:
<VirtualHost *:443>
DocumentRoot /var/www/subversion
ServerName svn.domain.com
ErrorLog "|/usr/bin/rotatelogs -l /var/log/subversion/svn-error.%Y.%m.%d 86400"
CustomLog /var/log/subversion/svn-access_log "%t %u %{SVN-ACTION}e" env=SVN-ACTION
<Location "/">
DAV svn
SVNPath /var/www/subversion
#Authenticated users only
Require valid-user
# authenticating them valid ones
AuthType Basic
AuthName "Subversion Repository"
AuthUserFile /var/www/passwd/.htpasswd-svn
order deny,allow
deny from all
satisfy any
</Location>
SSLEngine on
SSLCipherSuite ALL:!ADH:!EXPORT56:RC4+RSA:+HIGH:+MEDIUM:+LOW:+SSLv2:+EXP:+eNULL
SSLCACertificateFile /etc/ssl/local_certs/2018-domain.com/intermediate.crt
SSLCertificateFile /etc/ssl/local_certs/2018-domain.com/public.crt
SSLCertificateKeyFile /etc/ssl/local_certs/2018-domain.com/private.key
<FilesMatch "\.(cgi|shtml|phtml|php)$">
SSLOptions +StdEnvVars
</FilesMatch>
BrowserMatch ".*MSIE.*" \
nokeepalive ssl-unclean-shutdown \
downgrade-1.0 force-response-1.0
<Directory /var/www/subversion>
Options -Indexes
</Directory>
</VirtualHost>
尽管有这样的警告,但一切都运转正常,但是摆脱它会很好。
答案 0 :(得分:9)
您的虚拟主机配置很好,与警告无关。问题是由两个包含的配置文件创建的,这两个配置文件都加载mod_dav.so
:
mods-enabled/dav_svn.load
:将DAV模块作为依赖项加载mods-enabled/dav.load
:(显然) dav_svn.load
对此非常谨慎,如果模块尚未加载,则只包含dav.load
,但dav.load
没有此类检查。如果在dav.load
之前包含dav_svn.load
,这种方式可以正常工作,但显然在您的情况下不会发生(顺便提一下)。
我能够通过更改dav.load
的内容来摆脱警告
LoadModule dav_module /usr/lib/apache2/modules/mod_dav.so
到
<IfModule !mod_dav.c>
LoadModule dav_module /usr/lib/apache2/modules/mod_dav.so
</IfModule>