Large SVN checkout fails sporadically

前端 未结 5 1416
甜味超标
甜味超标 2021-02-04 00:23

I\'m currently experiencing issues during a large, full SVN repository checkout (20GB+), where the checkout process will halt randomly. The repository is composed of many small

相关标签:
5条回答
  • 2021-02-04 00:53

    I had the following errors:

    Unable to deliver content.  [500, #0]
    Could not write data to filter.  [500, #175002]
    

    I didn't even use the mod_deflate so that couldn't be it. In my case it turned out to be the authentication (auth_digest_module) causing the error. If a checkout lasts more than 300 seconds, I would have the above error logged in my Apache server log.

    The problem is the default AuthDigestNonceLifetime 300 directive. See here. My solution was to set this directive to infinity: AuthDigestNonceLifetime -1

    0 讨论(0)
  • 2021-02-04 00:55

    This seems to be an encoding problem of the files according to this post on the subversion maillinglist. You can either look for AddEncoding x-gzip .gz entries in your apache config and remove them or add this to your <Location /svn>…</Location> entry:

    RemoveEncoding .gz
    RemoveEncoding .Z
    

    This was actualy mentioned in the changelog, but neither did I care to read this and learned it the hard way…

    0 讨论(0)
  • 2021-02-04 00:59

    We've been running into this same problem recently. So far I think it has been related to newer subversion clients.

    Apache dav_svn_module directive

    SVNAllowBulkUpdates Prefer
    

    Seems to help. After adding that into apache conf, no issues have been found. Before that most of the large check outs failed.

    I found a discussion thread which explains the problems which are related to subversion clients that are newer than version 1.8.x. See the mailing list thread.

    0 讨论(0)
  • 2021-02-04 01:00

    One other possible cause I discovered for the "Could not write data to filter" errors is a NAT Loopback or Hairpin Loopback. We have our SVN Repository Server on a guest VM inside an ESXi host. SVN Clients within the same ESXi host were trying to reference the Repositories using a URL that would resolve out to the internet then "hairpin loopback" back into the LAN and ESXi host.

    SVN Client guest VMs on the same ESXi host would consistently get the following errors in /etc/httpd/logs/ssl_error_log when trying to do a TortoiseSVN Checkout:

    [dav:error] [pid 2204] Unable to deliver content.  [500, #0]
    [dav:error] [pid 2204] Could not write EOS to filter.  [500, #104]
    [dav:error] [pid 2204] Could not write data to filter  [500, #104]
    [dav:error] [pid 1687] Unable to deliver content.  [500, #0]
    [dav:error] [pid 1687] Could not write data to filter.  [500, #104]
    [dav:error] [pid 1687] Could not write data to filter  [500, #104]
    [dav:error] [pid 1686] Provider encountered an error while streaming a REPORT response.  [500, #0]
    [dav:error] [pid 1686] A failure occurred while driving the update report editor  [500, #32]
    [dav:error] [pid 1686] Broken pipe  [500, #32]
    

    The TortoiseSVN logs would simply say:

    ra_serf: An error occurred during SSL communication
    

    Fixed by changing the references to the SVN Repository URL using local IP addresses instead of a URL that resolved out to the internet. Other SVN clients in the same LAN but were not in ESXi, such as our laptops had no problem with the Loopback, only the SVN clients in ESXi had this error.

    0 讨论(0)
  • 2021-02-04 01:03

    I ran into the same problem attempting to do a snv checkout on a moderately sized (500MB) repository using a server consisting of Centos 7.4.1708, Apache 2.4.6, Subversion 1.9.15 and Windows 10 clients using TortoiseSVN 1.9.7 from behind an Apache Reverse Proxy.

    The solution for me was to add SVNAllowBulkUpdates Off similar to teori's answer. I attempted to use "SVNAllowBulkUpdates Prefer", but when I restarted httpd, it threw an error saying "SVNAllowBulkUpdates must be On or Off". My final SVN/Apache configuration file is:

    <Location /svn >
        DAV svn
        SVNParentPath /svn
        SVNAllowBulkUpdates Off
        AuthType Basic
        AuthName "SVN Repo"
        AuthUserFile /var/svn/svn-auth-user
        Require valid-user
    </Location>

    Other thoughts: I do not believe the Timeout and AuthDigestNonceLifetime settings are directly related to the problem. I did attempt to use them but neither had any effect. I specifically experimented with the timeout, keepalive and keepalivetimeout settings on both the SVN host and the reverse proxy host.

    The problem may be related to "deflating", but I also disabled it as Tim S. suggested and it also had not effect. The reason I still think it may be related is that, after eliminating the error, I noticed that the number of bytes transferred was substantially greater than before.

    0 讨论(0)
提交回复
热议问题