Class S3MetaRequest
- All Implemented Interfaces:
AutoCloseable
-
Nested Class Summary
Nested classes/interfaces inherited from class software.amazon.awssdk.crt.CrtResource
CrtResource.ResourceInstance -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionvoidcancel()voidincrementReadWindow(long bytes) Increment the flow-control window, so that response data continues downloading.pause()Pauses meta request and returns a token that can be used to resume a meta request.Methods inherited from class software.amazon.awssdk.crt.CrtResource
addRef, addReferenceTo, close, collectNativeResource, collectNativeResources, decRef, getNativeHandle, getResourceLogDescription, isNull, logNativeResources, logNativeResources, removeReferenceTo, setDescription, waitForNoResources
-
Constructor Details
-
S3MetaRequest
public S3MetaRequest()
-
-
Method Details
-
getShutdownCompleteFuture
-
cancel
public void cancel() -
pause
Pauses meta request and returns a token that can be used to resume a meta request. For PutObject resume, input stream should always start at the beginning, already uploaded parts will be skipped, but checksums on those will be verified if request specified checksum algo.- Returns:
- token to resume request. might be null if request has not started executing yet
-
incrementReadWindow
public void incrementReadWindow(long bytes) Increment the flow-control window, so that response data continues downloading.If the client was created with
S3ClientOptions.withReadBackpressureEnabled(boolean)set true, each S3MetaRequest has a flow-control window that shrinks as response body data is downloaded (headers do not affect the size of the window).S3ClientOptions.withInitialReadWindowSize(long)sets the starting size for each S3MetaRequest's window. Whenever the window reaches zero, data stops downloading. Increment the window to keep data flowing. Maintain a larger window to keep up a high download throughput, parts cannot download in parallel unless the window is large enough to hold multiple parts. Maintain a smaller window to limit the amount of data buffered in memory.If backpressure is disabled this call has no effect, data is downloaded as fast as possible.
WARNING: This feature is experimental. Currently, backpressure is only applied to GetObject requests which are split into multiple parts, and you may still receive some data after the window reaches zero.
- Parameters:
bytes- size to increment window by- See Also:
-