0

I'm running into various problems trying to add custom ErrorDocuments to my server.

I'm using proxy balancer to share the load between two instances of Zope and some simple rewrite rules to map my domain to the local zope instances. I'm pretty sure Zope isn't the problem, but have mentioned it to explain what the balancer redirects to.

I've tried a number of suggestions, but the 'closest' I can get is included below and results in the error:

"Firefox has detected that the server is redirecting the request for this address in a way that will never complete."

Other variations result in:

"The server is temporarily unable to service your request due to maintenance downtime or capacity problems. Please try again later.

Additionally, a 503 Service Temporarily Unavailable error was encountered while trying to use an ErrorDocument to handle the request."

If I include a simple

ErrorDocument 503 Hello

It renders fine.

What am I doing wrong? I'm worried that it may be something to do with the balancer/rewrite getting 'in the way' of the custom errors? Or that my DocumentRoot is incorrectly set?

The rest of this configuration runs fine without the custom errors.

<VirtualHost> VirtualHost XXX.XXX.XXX.XXX:80> ServerAdmin webmaster@localhost ServerName sub.domain.com <Proxy balancer://domain_dev> BalancerMember http://XXX.XXX.XXX.XXX:81 BalancerMember http://XXX.XXX.XXX.XXX:82 </Proxy> RewriteEngine On RewriteRule ^(.*)$ balancer://domain_dev$1 [P,L] <Location /> Order allow,deny Allow from all </Location> </VirtualHost> Listen 81 Listen 82 <VirtualHost XXX.XXX.XXX.XXX:81> CustomLog /var/log/apache2/domain-dev-1.log combined ErrorLog /var/log/apache2/domain-dev-error-1.log ErrorDocument 503 http://sub.domain.com/custom-errors/customerror.html Alias /customerrors /var/www/custom-errors/ RewriteEngine On RewriteRule ^(.*)$ http://localhost:6080/++skin++SandboxSkin/site/++vh++http:sub.domain.com:80/++$1 [P,L] RewriteLog /var/log/apache2/domain-dev-rewrite-1.log RewriteLogLevel 0 <Location /> Order allow,deny Allow from all </Location> </VirtualHost> <VirtualHost XXX.XXX.XXX.XXX:82> CustomLog /var/log/apache2/domain-dev-2.log combined ErrorLog /var/log/apache2/domain-dev-error-2.log RewriteEngine On RewriteRule ^(.*)$ http://localhost:6081/++skin++SandboxSkin/site/++vh++http:sub.domain.com:80/++$1 [P,L] RewriteLog /var/log/apache2/domain-dev-rewrite-2.log RewriteLogLevel 0 <Location /> Order allow,deny Allow from all </Location> </VirtualHost> 

1 Answer 1

2

Setting LogLevel Debug I found:

[Mon Sep 14 19:26:06 2009] [debug] proxy_util.c(2015): proxy: connected /++skin++SandboxSkin/site/++vh++http:sub.domain.com:80/++/custom-errors/customerror.html to localhost:6080 

Which confirmed that the proxy was trying to serve the error from the offline servers location.

Adding:

RewriteCond %{REQUEST_URI} !^/custom-errors/ 

Stopped the proxy rewriting any redirects with 'custom-errors' directories in the request.

After that, the following simplified ErrorDocument rule worked fine:

DocumentRoot "/var/www" ErrorDocument 503 "/custom-errors/customerror.html" 

You must log in to answer this question.

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.