Search in sources :

Example 6 with Node

use of io.prestosql.spi.Node in project hetu-core by openlookeng.

the class TpcdsSplitManager method getSplits.

@Override
public ConnectorSplitSource getSplits(ConnectorTransactionHandle transaction, ConnectorSession session, ConnectorTableLayoutHandle layout, SplitSchedulingStrategy splitSchedulingStrategy) {
    Set<Node> nodes = nodeManager.getRequiredWorkerNodes();
    checkState(!nodes.isEmpty(), "No TPCDS nodes available");
    int totalParts = nodes.size() * splitsPerNode;
    int partNumber = 0;
    ImmutableList.Builder<ConnectorSplit> splits = ImmutableList.builder();
    if (session.isSnapshotEnabled()) {
        // Snapshot: Modify splits as needed to all them to be scheduled on any node.
        // This allows them to be processed by a different worker after resume.
        List<HostAddress> addresses = nodes.stream().map(Node::getHostAndPort).collect(Collectors.toList());
        for (int i = 0; i < totalParts; i++) {
            splits.add(new TpcdsSplit(partNumber, totalParts, addresses, noSexism));
            partNumber++;
        }
    } else {
        // Split the data using split and skew by the number of nodes available.
        for (Node node : nodes) {
            for (int i = 0; i < splitsPerNode; i++) {
                splits.add(new TpcdsSplit(partNumber, totalParts, ImmutableList.of(node.getHostAndPort()), noSexism));
                partNumber++;
            }
        }
    }
    return new FixedSplitSource(splits.build());
}
Also used : ImmutableList(com.google.common.collect.ImmutableList) FixedSplitSource(io.prestosql.spi.connector.FixedSplitSource) Node(io.prestosql.spi.Node) HostAddress(io.prestosql.spi.HostAddress) ConnectorSplit(io.prestosql.spi.connector.ConnectorSplit)

Aggregations

Node (io.prestosql.spi.Node)6 ImmutableList (com.google.common.collect.ImmutableList)4 ConnectorSplit (io.prestosql.spi.connector.ConnectorSplit)4 FixedSplitSource (io.prestosql.spi.connector.FixedSplitSource)3 HostAddress (io.prestosql.spi.HostAddress)2 HashSet (java.util.HashSet)2 ImmutableList.toImmutableList (com.google.common.collect.ImmutableList.toImmutableList)1 Gson (com.google.gson.Gson)1 InternalNode (io.prestosql.metadata.InternalNode)1 PrestoException (io.prestosql.spi.PrestoException)1 ColumnHandle (io.prestosql.spi.connector.ColumnHandle)1 ColumnMetadata (io.prestosql.spi.connector.ColumnMetadata)1 ConnectorSplitSource (io.prestosql.spi.connector.ConnectorSplitSource)1 Constraint (io.prestosql.spi.connector.Constraint)1 SchemaTableName (io.prestosql.spi.connector.SchemaTableName)1 Domain (io.prestosql.spi.predicate.Domain)1 BufferedReader (java.io.BufferedReader)1 IOException (java.io.IOException)1 InputStreamReader (java.io.InputStreamReader)1 Type (java.lang.reflect.Type)1