Document exec chain behaviour when automatic retries are enabled. (#480)

This commit is contained in:
cachescrubber 2023-08-31 16:55:37 +02:00 committed by GitHub
parent f00e18d9cc
commit 509ba6753f
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 66 additions and 1 deletions

View File

@ -28,6 +28,9 @@ package org.apache.hc.client5.http.async;
import java.io.IOException; import java.io.IOException;
import org.apache.hc.client5.http.impl.ChainElement;
import org.apache.hc.client5.http.impl.async.AsyncHttpRequestRetryExec;
import org.apache.hc.client5.http.impl.async.HttpAsyncClientBuilder;
import org.apache.hc.core5.annotation.Contract; import org.apache.hc.core5.annotation.Contract;
import org.apache.hc.core5.annotation.ThreadingBehavior; import org.apache.hc.core5.annotation.ThreadingBehavior;
import org.apache.hc.core5.http.HttpException; import org.apache.hc.core5.http.HttpException;
@ -39,8 +42,20 @@ import org.apache.hc.core5.http.nio.AsyncEntityProducer;
* chain. Handlers can either be a decorator around another element that implements * chain. Handlers can either be a decorator around another element that implements
* a cross cutting aspect or a self-contained executor capable of producing a response * a cross cutting aspect or a self-contained executor capable of producing a response
* for the given request. * for the given request.
* * <p>
* For information regarding the handler chain behaviour in case of a request re-execution,
* please refer to the {@link AsyncHttpRequestRetryExec} javadoc.
* </p>
* <p>
* Well known request execution handlers could be referred to by name using one of the
* {@link ChainElement} enum values.
* </p>
* @since 5.0 * @since 5.0
* @see ChainElement
* @see HttpAsyncClientBuilder#addExecInterceptorFirst(String, AsyncExecChainHandler)
* @see HttpAsyncClientBuilder#addExecInterceptorBefore(String, String, AsyncExecChainHandler)
* @see HttpAsyncClientBuilder#addExecInterceptorAfter(String, String, AsyncExecChainHandler)
* @see HttpAsyncClientBuilder#addExecInterceptorLast(String, AsyncExecChainHandler)
*/ */
@Contract(threading = ThreadingBehavior.STATELESS) @Contract(threading = ThreadingBehavior.STATELESS)
public interface AsyncExecChainHandler { public interface AsyncExecChainHandler {

View File

@ -29,6 +29,9 @@ package org.apache.hc.client5.http.classic;
import java.io.IOException; import java.io.IOException;
import org.apache.hc.client5.http.impl.ChainElement;
import org.apache.hc.client5.http.impl.classic.HttpClientBuilder;
import org.apache.hc.client5.http.impl.classic.HttpRequestRetryExec;
import org.apache.hc.core5.annotation.Contract; import org.apache.hc.core5.annotation.Contract;
import org.apache.hc.core5.annotation.ThreadingBehavior; import org.apache.hc.core5.annotation.ThreadingBehavior;
import org.apache.hc.core5.http.ClassicHttpRequest; import org.apache.hc.core5.http.ClassicHttpRequest;
@ -46,8 +49,21 @@ import org.apache.hc.core5.http.HttpException;
* by calling {@link ClassicHttpResponse#close()} methods in case of an I/O, protocol or * by calling {@link ClassicHttpResponse#close()} methods in case of an I/O, protocol or
* runtime exception, or in case the response is not propagated to the caller. * runtime exception, or in case the response is not propagated to the caller.
* </p> * </p>
* <p>
* For information regarding the handler chain behaviour in case of a request re-execution,
* please refer to the {@link HttpRequestRetryExec} javadoc.
* </p>
*<p>
* Well known request execution handlers could be referred to by name using one of the
* {@link ChainElement} enum values.
*</p>
* *
* @since 4.3 * @since 4.3
* @see ChainElement
* @see HttpClientBuilder#addExecInterceptorFirst(String, ExecChainHandler)
* @see HttpClientBuilder#addExecInterceptorBefore(String, String, ExecChainHandler)
* @see HttpClientBuilder#addExecInterceptorAfter(String, String, ExecChainHandler)
* @see HttpClientBuilder#addExecInterceptorLast(String, ExecChainHandler)
*/ */
@Contract(threading = ThreadingBehavior.STATELESS) @Contract(threading = ThreadingBehavior.STATELESS)
public interface ExecChainHandler { public interface ExecChainHandler {

View File

@ -33,6 +33,7 @@ import org.apache.hc.client5.http.HttpRoute;
import org.apache.hc.client5.http.async.AsyncExecCallback; import org.apache.hc.client5.http.async.AsyncExecCallback;
import org.apache.hc.client5.http.async.AsyncExecChain; import org.apache.hc.client5.http.async.AsyncExecChain;
import org.apache.hc.client5.http.async.AsyncExecChainHandler; import org.apache.hc.client5.http.async.AsyncExecChainHandler;
import org.apache.hc.client5.http.impl.ChainElement;
import org.apache.hc.client5.http.protocol.HttpClientContext; import org.apache.hc.client5.http.protocol.HttpClientContext;
import org.apache.hc.core5.annotation.Contract; import org.apache.hc.core5.annotation.Contract;
import org.apache.hc.core5.annotation.Internal; import org.apache.hc.core5.annotation.Internal;
@ -61,6 +62,22 @@ import org.slf4j.LoggerFactory;
* endpoint is delegated to the next executor in the request execution * endpoint is delegated to the next executor in the request execution
* chain. * chain.
* </p> * </p>
* <p>
* If this handler is active, pay particular attention to the placement
* of other handlers within the handler chain relative to the retry handler.
* Use {@link ChainElement#RETRY} as name when referring to this handler.
* </p>
* <p>
* If a custom handler is placed <b>before</b> the retry handler, the handler will
* see the initial request and the final outcome after the last retry. Elapsed time
* will account for any delays imposed by the retry handler.
* </p>
*
* <p>
* A custom handler which is placed <b>after</b> the retry handler will be invoked for
* each individual retry. Elapsed time will measure each individual http request,
* without the delay imposed by the retry handler.
* </p>
* *
* @since 5.0 * @since 5.0
*/ */

View File

@ -35,6 +35,7 @@ import org.apache.hc.client5.http.classic.ExecChain;
import org.apache.hc.client5.http.classic.ExecChain.Scope; import org.apache.hc.client5.http.classic.ExecChain.Scope;
import org.apache.hc.client5.http.classic.ExecChainHandler; import org.apache.hc.client5.http.classic.ExecChainHandler;
import org.apache.hc.client5.http.config.RequestConfig; import org.apache.hc.client5.http.config.RequestConfig;
import org.apache.hc.client5.http.impl.ChainElement;
import org.apache.hc.client5.http.protocol.HttpClientContext; import org.apache.hc.client5.http.protocol.HttpClientContext;
import org.apache.hc.core5.annotation.Contract; import org.apache.hc.core5.annotation.Contract;
import org.apache.hc.core5.annotation.Internal; import org.apache.hc.core5.annotation.Internal;
@ -61,6 +62,22 @@ import org.slf4j.LoggerFactory;
* endpoint is delegated to the next executor in the request execution * endpoint is delegated to the next executor in the request execution
* chain. * chain.
* </p> * </p>
* <p>
* If this handler is active, pay particular attention to the placement
* of other handlers within the handler chain relative to the retry handler.
* Use {@link ChainElement#RETRY} as name when referring to this handler.
* </p>
* <p>
* If a custom handler is placed <b>before</b> the retry handler, the handler will
* see the initial request and the final outcome after the last retry. Elapsed time
* will account for any delays imposed by the retry handler.
* </p>
*
* <p>
* A custom handler which is placed <b>after</b> the retry handler will be invoked for
* each individual retry. Elapsed time will measure each individual http request,
* without the delay imposed by the retry handler.
* </p>
* *
* @since 5.0 * @since 5.0
*/ */