Class ParallelStream
java.lang.Object
org.apache.solr.client.solrj.io.stream.TupleStream
org.apache.solr.client.solrj.io.stream.CloudSolrStream
org.apache.solr.client.solrj.io.stream.ParallelStream
- All Implemented Interfaces:
Closeable,Serializable,AutoCloseable,Expressible,org.apache.solr.common.MapSerializable,org.apache.solr.common.MapWriter,org.apache.solr.common.NavigableObject,org.noggit.JSONWriter.Writable
The ParallelStream decorates a TupleStream implementation and pushes it to N workers for parallel
execution. Workers are chosen from a SolrCloud collection. Tuples that are streamed back from the
workers are ordered by a Comparator.
- Since:
- 5.1.0
- See Also:
-
Nested Class Summary
Nested classes/interfaces inherited from class org.apache.solr.client.solrj.io.stream.CloudSolrStream
CloudSolrStream.StreamOpener, CloudSolrStream.TupleWrapperNested classes/interfaces inherited from class org.apache.solr.client.solrj.io.stream.TupleStream
TupleStream.IgnoreExceptionNested classes/interfaces inherited from interface org.apache.solr.common.MapWriter
org.apache.solr.common.MapWriter.EntryWriter -
Field Summary
Fields inherited from class org.apache.solr.client.solrj.io.stream.CloudSolrStream
collection, comp, eofTuples, fieldMappings, params, solrStreams, streamContext, tuples, zkHostFields inherited from interface org.apache.solr.common.MapWriter
EMPTY -
Constructor Summary
ConstructorsConstructorDescriptionParallelStream(String zkHost, String collection, String expressionString, int workers, StreamComparator comp) ParallelStream(String zkHost, String collection, TupleStream tupleStream, int workers, StreamComparator comp) ParallelStream(StreamExpression expression, StreamFactory factory) -
Method Summary
Modifier and TypeMethodDescriptionchildren()protected voidread()voidsetStreamContext(StreamContext streamContext) voidsetStreamFactory(StreamFactory streamFactory) toExplanation(StreamFactory factory) Returns an explanation about the stream objecttoExpression(StreamFactory factory) Methods inherited from class org.apache.solr.client.solrj.io.stream.CloudSolrStream
_read, adjustParams, close, getEofTuples, getSlices, getStreamSort, open, setFieldMappings, setTraceMethods inherited from class org.apache.solr.client.solrj.io.stream.TupleStream
getCost, getShards, getShards, getStreamNodeId, writeMapMethods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface org.apache.solr.common.MapWriter
jsonStr, toMap, writeMethods inherited from interface org.apache.solr.common.NavigableObject
_forEachEntry, _forEachEntry, _forEachEntry, _get, _get, _getStr, _getStr, _size
-
Constructor Details
-
ParallelStream
public ParallelStream(String zkHost, String collection, TupleStream tupleStream, int workers, StreamComparator comp) throws IOException - Throws:
IOException
-
ParallelStream
public ParallelStream(String zkHost, String collection, String expressionString, int workers, StreamComparator comp) throws IOException - Throws:
IOException
-
ParallelStream
- Throws:
IOException
-
-
Method Details
-
setStreamFactory
-
toExpression
- Specified by:
toExpressionin interfaceExpressible- Overrides:
toExpressionin classCloudSolrStream- Throws:
IOException
-
toExplanation
Description copied from interface:ExpressibleReturns an explanation about the stream object- Specified by:
toExplanationin interfaceExpressible- Overrides:
toExplanationin classCloudSolrStream- Parameters:
factory- Stream factory for this, contains information about the function name- Returns:
- Explanation about this stream object containing explanations of any child stream objects
- Throws:
IOException- throw on any error
-
children
- Overrides:
childrenin classCloudSolrStream
-
read
- Overrides:
readin classCloudSolrStream- Throws:
IOException
-
setStreamContext
- Overrides:
setStreamContextin classCloudSolrStream
-
constructStreams
- Overrides:
constructStreamsin classCloudSolrStream- Throws:
IOException
-