Cooperative parse
By default, Vertica parses a data source in a single thread on one database node. You can optionally use cooperative parse to parse a source using multiple threads on a node. More specifically, data from a source passes through a chunker that groups blocks from the source stream into logical units. These chunks can be parsed in parallel. The chunker divides the input into pieces that can be individually parsed, and the parser then parses them concurrently. Cooperative parse is available only for unfenced UDxs. (See Fenced and unfenced modes.)
To use cooperative parse, a chunker must be able to locate end-of-record markers in the input. Locating these markers might not be possible in all input formats.
Chunkers are created by parser factories. At load time, Vertica first calls the UDChunker
to divide the input into chunks and then calls the UDParser
to parse each chunk.
You can use cooperative parse and apportioned load independently or together. See Combining cooperative parse and apportioned load.
How Vertica divides a load
When Vertica receives data from a source, it calls the chunker's process()
method repeatedly. A chunker is, essentially, a lightweight parser; instead of parsing, the process()
method divides the input into chunks.
After the chunker has finished dividing the input into chunks, Vertica sends those chunks to as many parsers as are available, calling the process()
method on the parser.
Implementing cooperative parse
To implement cooperative parse, perform the following actions:
-
Subclass
UDChunker
and implementprocess()
. -
In your
ParserFactory
, implementprepareChunker()
to return aUDChunker
.
See C++ example: delimited parser and chunker for a UDChunker
that also supports apportioned load.