SVN com erros do caminho de configuração do apache2

0

Acabei de configurar svn over https (com apache2 ). Eu posso svn checkout fine, no entanto os commits estão falhando. Eu posso ver a partir do apache2 logs que o servidor svn está procurando no lugar errado para encontrar o repositório para fazer o commit. Aqui está o meu arquivo apache2 443.example.com.conf:

<IfModule mod_ssl.c>
    <virtualhost *:443>
    # requests to https://example.com land here
    ServerName example.com
    DocumentRoot /home/me/svn-repos

    # global properties for all directories in this site
    <Location />
        # do not use .htaccess files
        allowoverride none
        #DirectoryIndex index.html
        #require all granted                                                                                    

        DAV svn
        SVNParentPath /home/me/svn-repos
        AuthType Basic
        AuthName "svn repositories"
        AuthUserFile blah.passwd
        #<LimitExcept GET PROPFIND OPTIONS REPORT>
        Require valid-user
        #</LimitExcept>
    </Location>

    SSLEngine On
    SSLCertificateFile blah
    SSLCertificateKeyFile blah

    <FilesMatch "\.(cgi|shtml|phtml|php)$">
            SSLOptions +StdEnvVars
    </FilesMatch>

    ErrorDocument 400 /index.html
    ErrorDocument 401 /index.html
    # lots more ErrorDocument entries

    </virtualhost>
</IfModule>

Observe que todos os meus repositórios svn estão nos diretórios em /home/me/svn-repos (por exemplo, /home/me/svn-repos/repo1 , /home/me/svn-repos/repo2 , etc)

Então, confiro uma cópia local atualizada de um dos meus repositórios:

$ cd /tmp
$ svn co --username me https://example.com/repo1 repo1
Authentication realm: <https://example.com:443> svn repositories
Password for 'me': ***

A repo1/file1.txt
Checked out revision 1.

Até aí tudo bem. Mas quando eu tento me comprometer:

$ touch file2.txt
$ svn add file2.txt
A     file2.txt
$ svn ci file2.txt -m added
Authentication realm: <https://example.com:443> svn repositories
Password for 'me': ***

Adding         file2.txt
svn: E175009: Commit failed (details follow):
svn: E175009: The XML response contains invalid XML
svn: E130003: Malformed XML: no element found

E posso ver no log de erros apache2 que svn server está procurando no lugar errado para o repositório:

$ sudo tail -4 /var/log/apache2/error.log
[Sat Dec 02 20:23:29.626227 2017] [:error] [pid 123] (20014)Internal error (specific information not available): [client x.x.x.x:x] Can't open file '/home/me/svn-repos/index.html/format': Not a directory
[Sat Dec 02 20:23:29.626264 2017] [dav:error] [pid 123] [client x.x.x.x:x] Could not fetch resource information.  [404, #0]
[Sat Dec 02 20:23:29.626272 2017] [dav:error] [pid 123] [client x.x.x.x:x] Could not find the requested SVN filesystem  [404, #20]
[Sat Dec 02 20:23:29.626277 2017] [dav:error] [pid 123] [client x.x.x.x:x] Could not find the requested SVN filesystem  [404, #20]

O arquivo que ele está procurando é /home/me/svn-repos/repo1/format , mas não está anexando o caminho correto para encontrar o arquivo. Eu suspeito que isso significa que eu preciso colocar algo no meu arquivo apache2 443.example.com.conf, mas não consigo pensar em quê.

Atualizar

Eu fiz a seguinte alteração no arquivo 443.example.com.conf:

# ErrorDocument 404 /index.html
ErrorDocument 404 /indexyz.html

E agora, quando tento fazer o commit, a mensagem de erro é alterada para:

[Sat Dec 02 20:39:00.153942 2017] [:error] [pid 123] (20014)Internal error (specific information not available): [client 192.168.1.177:50228] Can't open file '/home/me/svn-repos/indexyz.html/format': No such file or directory
[Sat Dec 02 20:39:00.153979 2017] [dav:error] [pid 123] [client x.x.x.x:x] Could not fetch resource information.  [404, #0]
[Sat Dec 02 20:39:00.153987 2017] [dav:error] [pid 123] [client x.x.x.x:x] Could not find the requested SVN filesystem  [404, #2]
[Sat Dec 02 20:39:00.153992 2017] [dav:error] [pid 123] [client x.x.x.x:x] Could not find the requested SVN filesystem  [404, #2]

Mas isso ainda não ajuda muito.

    
por mulllhausen 04.12.2017 / 12:40

2 respostas

0

Eu finalmente consegui trabalhar. No final, não tinha nada a ver com a raiz do documento, eram as declarações do ErrorDocument - eu só precisava alterá-las de /index.html para default . Minha configuração final é assim:

<IfModule mod_ssl.c>
    <virtualhost *:443>
        # requests to https://example.com land here
        ServerName example.com
        DocumentRoot /home/me/svn-repos

        # global properties for all directories in this site
        <Location />
            # do not use .htaccess files
            allowoverride none

            DAV svn
            SVNParentPath /home/me/svn-repos
            AuthType Basic
            AuthName "svn repositories"
            AuthUserFile blah.passwd
            Require valid-user
        </Location>

        # http://svnbook.red-bean.com/en/1.7/svn.serverconfig.httpd.html
        CustomLog ${APACHE_LOG_DIR}/svn_logfile "%t %u %{SVN-ACTION}e" env=SVN-ACTION
        ErrorLog ${APACHE_LOG_DIR}/error.log

        SSLEngine On
        SSLCertificateFile fullchain.pem
        SSLCertificateKeyFile privkey.pem

        <FilesMatch "\.(cgi|shtml|phtml|php)$">
                SSLOptions +StdEnvVars
        </FilesMatch>

        ErrorDocument 400 default
        ErrorDocument 401 default
        ErrorDocument 402 default
        ErrorDocument 403 default
        ErrorDocument 404 default
        ErrorDocument 405 default
        ErrorDocument 406 default
        ErrorDocument 407 default
        ErrorDocument 408 default
        ErrorDocument 409 default
        ErrorDocument 410 default
        ErrorDocument 411 default
        ErrorDocument 412 default
        ErrorDocument 413 default
        ErrorDocument 414 default
        ErrorDocument 415 default
        ErrorDocument 416 default
        ErrorDocument 417 default
        #ErrorDocument 418 default
        ErrorDocument 421 default
        ErrorDocument 422 default
        ErrorDocument 423 default
        ErrorDocument 424 default
        ErrorDocument 426 default
        ErrorDocument 428 default
        ErrorDocument 429 default
        ErrorDocument 431 default
        ErrorDocument 451 default
        ErrorDocument 500 default
        ErrorDocument 501 default
        ErrorDocument 502 default
        ErrorDocument 503 default
        ErrorDocument 504 default
        ErrorDocument 505 default
        ErrorDocument 506 default
        ErrorDocument 507 default
        ErrorDocument 508 default
        ErrorDocument 510 default
        ErrorDocument 511 default
    </virtualhost>
</IfModule> 
    
por 06.12.2017 / 12:14
1
  1. Você fez todos os erros possíveis (3/3)
  2. Você não leu o SVN Book

Corrigir:

  • Repos não deve estar dentro da http-tree
  • O local do SVN não deve estar na raiz do http-host
  • A localização do SVN não deve estar no caminho físico dentro do http-host, apenas na lógica
por 04.12.2017 / 13:53