into the proxy handler of mod_proxy.
This patch still sets r->connection->aborted to 1 which is currently
vetoed by Roy. Moving it from the scheme handler to the proxy handler
should ease the reimplementation of this, as the scheme handlers only
needs to return PROXY_BACKEND_BROKEN to signal the above situation to
the proxy handler.
mod_proxy.h: Add define for PROXY_BACKEND_BROKEN
mod_proxy.c: Handle PROXY_BACKEND_BROKEN in proxy handler
mod_proxy_http.c: Sent back PROXY_BACKEND_BROKEN if backend broke
after we sent the headers.
git-svn-id: https://svn.apache.org/repos/asf/httpd/httpd/trunk@355823
13f79535-47bb-0310-9956-
ffa450edef68
worker->s->status |= PROXY_WORKER_IN_ERROR;
}
}
+ else if (access_status == PROXY_BACKEND_BROKEN) {
+ /*
+ * If the backend broke after the headers had been sent do not
+ * try another worker, but leave. Do not mark the worker as
+ * unsuable as this problem may not reoccur on the next request.
+ *
+ * TODO: Currently we abort the connection and notify all parties
+ * on the upstream that something went wrong by setting c->aborted
+ * to 1. This idea is currently vetoed and should be replaced with
+ * other methods
+ */
+ r->connection->aborted = 1;
+ break;
+ }
else {
/* Unrecoverable error.
* Return the origin status code to the client.
proxy_conn_rec *conn; /* Single connection for prefork mpm's */
};
+/*
+ * Return code that scheme handlers should return if the backend connection
+ * broke after they have sent the headers
+ */
+#define PROXY_BACKEND_BROKEN -10
+
/* woker status flags */
#define PROXY_WORKER_INITIALIZED 0x0001
#define PROXY_WORKER_IGNORE_ERRORS 0x0002
* are being read. */
int pread_len = 0;
apr_table_t *save_table;
+ int backend_broken = 0;
bb = apr_brigade_create(p, c->bucket_alloc);
*/
ap_log_cerror(APLOG_MARK, APLOG_ERR, rv, c,
"proxy: error reading response");
- c->aborted = 1;
+ backend_broken = 1;
break;
}
/* next time try a non-blocking read */
}
} while (interim_response);
- /* If our connection with the client is to be aborted, return DONE. */
- if (c->aborted) {
- return DONE;
+ /* Signal back that the backend broke after we sent the headers. */
+ if (backend_broken) {
+ return PROXY_BACKEND_BROKEN;
}
if (conf->error_override) {