Package org.apache.druid.data.input.impl
Class RetryingInputStream<T>
- java.lang.Object
-
- java.io.InputStream
-
- org.apache.druid.data.input.impl.RetryingInputStream<T>
-
- Type Parameters:
T- object type
- All Implemented Interfaces:
Closeable,AutoCloseable
public class RetryingInputStream<T> extends InputStream
This class is responsible for re-opening the underlying input stream for the input object on the givenretryCondition.
-
-
Constructor Summary
Constructors Constructor Description RetryingInputStream(T object, ObjectOpenFunction<T> objectOpenFunction, com.google.common.base.Predicate<Throwable> retryCondition, Integer maxTries)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description intavailable()voidclose()intread()intread(byte[] b)intread(byte[] b, int off, int len)longskip(long n)-
Methods inherited from class java.io.InputStream
mark, markSupported, nullInputStream, readAllBytes, readNBytes, readNBytes, reset, transferTo
-
-
-
-
Constructor Detail
-
RetryingInputStream
public RetryingInputStream(T object, ObjectOpenFunction<T> objectOpenFunction, com.google.common.base.Predicate<Throwable> retryCondition, @Nullable Integer maxTries) throws IOException
- Parameters:
object- The object entity to openobjectOpenFunction- How to open the objectretryCondition- A predicate on a throwable to indicate if stream should retry.maxTries- The maximum times to try. Defaults toRetryUtils.DEFAULT_MAX_TRIESwhen null- Throws:
IOException
-
-
Method Detail
-
read
public int read() throws IOException- Specified by:
readin classInputStream- Throws:
IOException
-
read
public int read(byte[] b) throws IOException- Overrides:
readin classInputStream- Throws:
IOException
-
read
public int read(byte[] b, int off, int len) throws IOException- Overrides:
readin classInputStream- Throws:
IOException
-
skip
public long skip(long n) throws IOException- Overrides:
skipin classInputStream- Throws:
IOException
-
available
public int available() throws IOException- Overrides:
availablein classInputStream- Throws:
IOException
-
close
public void close() throws IOException- Specified by:
closein interfaceAutoCloseable- Specified by:
closein interfaceCloseable- Overrides:
closein classInputStream- Throws:
IOException
-
-