Ubuntu上的Apache:模块dav_module已经加载

时间:2018-05-08 10:08:36

标签: apache ubuntu svn module

我刚将我的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>

尽管有这样的警告,但一切都运转正常,但是摆脱它会很好。

1 个答案:

答案 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>