public class S3ObjectInputStream extends SdkFilterInputStream
S3Object
. In addition to
the methods supplied by the InputStream
class,
S3ObjectInputStream
supplies the abort() method, which will terminate
an HTTP connection to the S3 object.Constructor and Description |
---|
S3ObjectInputStream(InputStream in,
org.apache.http.client.methods.HttpRequestBase httpRequest) |
S3ObjectInputStream(InputStream in,
org.apache.http.client.methods.HttpRequestBase httpRequest,
boolean collectMetrics) |
Modifier and Type | Method and Description |
---|---|
void |
abort()
Can be used to provide abortion logic prior to throwing the
AbortedException.
|
int |
available()
Returns the value of super.available() if the result is nonzero, or 1
otherwise.
|
void |
close()
If the stream still contains unread data, the underlying HTTP request
will aborted.
|
org.apache.http.client.methods.HttpRequestBase |
getHttpRequest()
Returns the http request from which this input stream is derived.
|
getDelegateStream, isMetricActivated, mark, markSupported, read, read, release, reset, skip
read
public S3ObjectInputStream(InputStream in, org.apache.http.client.methods.HttpRequestBase httpRequest)
public S3ObjectInputStream(InputStream in, org.apache.http.client.methods.HttpRequestBase httpRequest, boolean collectMetrics)
public void abort()
InputStream
is also an instance
of this class, then it will also be aborted, otherwise this is a no-op.
Aborts the underlying http request without reading any more data and
closes the stream.
By default Apache HttpClient
tries to reuse http connections by
reading to the end of an attached input stream on
InputStream.close()
. This is efficient from a socket pool
management perspective, but for objects with large payloads can incur
significant overhead while bytes are read from s3 and discarded. It's up
to clients to decide when to take the performance hit implicit in not
reusing an http connection in order to not read unnecessary information
from S3.
abort
in class SdkFilterInputStream
EofSensorInputStream
public org.apache.http.client.methods.HttpRequestBase getHttpRequest()
public int available() throws IOException
This is necessary to work around a known bug in GZIPInputStream.available(), which returns zero in some edge cases, causing file truncation.
Ref: http://bugs.java.com/bugdatabase/view_bug.do?bug_id=7036144
available
in class SdkFilterInputStream
IOException
public void close() throws IOException
close
in interface Closeable
close
in interface AutoCloseable
close
in class SdkFilterInputStream
IOException
abort()
,
S3AbortableInputStream