mirror of
https://github.com/apache/httpd.git
synced 2025-08-08 15:02:10 +03:00
Fix pool lifetime issues when the proxy backend connection is terminated
early by forcing a setaside on transient buckets placed in the brigade by mod_ssl. This has the effect of extending the lifetime of buckets until the end of the request. This is a variation on the original fix for this problem, which added transient buckets to be setaside later in the process. git-svn-id: https://svn.apache.org/repos/asf/httpd/httpd/trunk@1035504 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
@@ -2643,19 +2643,17 @@ PROXY_DECLARE(int) ap_proxy_connection_create(const char *proxy_function,
|
||||
apr_sockaddr_t *backend_addr = conn->addr;
|
||||
int rc;
|
||||
apr_interval_time_t current_timeout;
|
||||
apr_bucket_alloc_t *bucket_alloc;
|
||||
|
||||
if (conn->connection) {
|
||||
return OK;
|
||||
}
|
||||
|
||||
bucket_alloc = apr_bucket_alloc_create(conn->scpool);
|
||||
/*
|
||||
* The socket is now open, create a new backend server connection
|
||||
*/
|
||||
conn->connection = ap_run_create_connection(conn->scpool, s, conn->sock,
|
||||
0, NULL,
|
||||
bucket_alloc);
|
||||
c->bucket_alloc);
|
||||
|
||||
if (!conn->connection) {
|
||||
/*
|
||||
@@ -2742,56 +2740,6 @@ PROXY_DECLARE(void) ap_proxy_backend_broke(request_rec *r,
|
||||
APR_BRIGADE_INSERT_TAIL(brigade, e);
|
||||
}
|
||||
|
||||
/*
|
||||
* Transform buckets from one bucket allocator to another one by creating a
|
||||
* transient bucket for each data bucket and let it use the data read from
|
||||
* the old bucket. Metabuckets are transformed by just recreating them.
|
||||
* Attention: Currently only the following bucket types are handled:
|
||||
*
|
||||
* All data buckets
|
||||
* FLUSH
|
||||
* EOS
|
||||
*
|
||||
* If an other bucket type is found its type is logged as a debug message
|
||||
* and APR_EGENERAL is returned.
|
||||
*/
|
||||
PROXY_DECLARE(apr_status_t)
|
||||
ap_proxy_buckets_lifetime_transform(request_rec *r, apr_bucket_brigade *from,
|
||||
apr_bucket_brigade *to)
|
||||
{
|
||||
apr_bucket *e;
|
||||
apr_bucket *new;
|
||||
const char *data;
|
||||
apr_size_t bytes;
|
||||
apr_status_t rv = APR_SUCCESS;
|
||||
|
||||
apr_brigade_cleanup(to);
|
||||
for (e = APR_BRIGADE_FIRST(from);
|
||||
e != APR_BRIGADE_SENTINEL(from);
|
||||
e = APR_BUCKET_NEXT(e)) {
|
||||
if (!APR_BUCKET_IS_METADATA(e)) {
|
||||
apr_bucket_read(e, &data, &bytes, APR_BLOCK_READ);
|
||||
new = apr_bucket_transient_create(data, bytes, r->connection->bucket_alloc);
|
||||
APR_BRIGADE_INSERT_TAIL(to, new);
|
||||
}
|
||||
else if (APR_BUCKET_IS_FLUSH(e)) {
|
||||
new = apr_bucket_flush_create(r->connection->bucket_alloc);
|
||||
APR_BRIGADE_INSERT_TAIL(to, new);
|
||||
}
|
||||
else if (APR_BUCKET_IS_EOS(e)) {
|
||||
new = apr_bucket_eos_create(r->connection->bucket_alloc);
|
||||
APR_BRIGADE_INSERT_TAIL(to, new);
|
||||
}
|
||||
else {
|
||||
ap_log_rerror(APLOG_MARK, APLOG_DEBUG, 0, r,
|
||||
"proxy: Unhandled bucket type of type %s in"
|
||||
" ap_proxy_buckets_lifetime_transform", e->type->name);
|
||||
rv = APR_EGENERAL;
|
||||
}
|
||||
}
|
||||
return rv;
|
||||
}
|
||||
|
||||
/*
|
||||
* Provide a string hashing function for the proxy.
|
||||
* We offer 2 methods: one is the APR model but we
|
||||
|
Reference in New Issue
Block a user