blob: ca5a2bca94bdf2d9f529f567fb15de690c3eefaa [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
package org.apache.nemo.runtime.executor.datatransfer;
import org.apache.nemo.common.ir.OutputCollector;
import org.apache.nemo.common.ir.vertex.IRVertex;
import org.apache.nemo.common.ir.vertex.OperatorVertex;
import org.apache.nemo.common.punctuation.Watermark;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import java.util.List;
import java.util.Map;
/**
* OutputCollector implementation.
* This emits four types of outputs
* 1) internal main outputs: this output becomes the input of internal Transforms
* 2) internal additional outputs: this additional output becomes the input of internal Transforms
* 3) external main outputs: this external output is emitted to OutputWriter
* 4) external additional outputs: this external output is emitted to OutputWriter
*
* @param <O> output type.
*/
public final class OperatorVertexOutputCollector<O> implements OutputCollector<O> {
private static final Logger LOG = LoggerFactory.getLogger(OperatorVertexOutputCollector.class.getName());
private final IRVertex irVertex;
private final List<NextIntraTaskOperatorInfo> internalMainOutputs;
private final Map<String, List<NextIntraTaskOperatorInfo>> internalAdditionalOutputs;
private final List<OutputWriter> externalMainOutputs;
private final Map<String, List<OutputWriter>> externalAdditionalOutputs;
/**
* Constructor of the output collector.
*
* @param irVertex the ir vertex that emits the output
* @param internalMainOutputs internal main outputs
* @param internalAdditionalOutputs internal additional outputs
* @param externalMainOutputs external main outputs
* @param externalAdditionalOutputs external additional outputs
*/
public OperatorVertexOutputCollector(
final IRVertex irVertex,
final List<NextIntraTaskOperatorInfo> internalMainOutputs,
final Map<String, List<NextIntraTaskOperatorInfo>> internalAdditionalOutputs,
final List<OutputWriter> externalMainOutputs,
final Map<String, List<OutputWriter>> externalAdditionalOutputs) {
this.irVertex = irVertex;
this.internalMainOutputs = internalMainOutputs;
this.internalAdditionalOutputs = internalAdditionalOutputs;
this.externalMainOutputs = externalMainOutputs;
this.externalAdditionalOutputs = externalAdditionalOutputs;
}
private void emit(final OperatorVertex vertex, final O output) {
vertex.getTransform().onData(output);
}
private void emit(final OutputWriter writer, final O output) {
writer.write(output);
}
@Override
public void emit(final O output) {
for (final NextIntraTaskOperatorInfo internalVertex : internalMainOutputs) {
emit(internalVertex.getNextOperator(), output);
}
for (final OutputWriter externalWriter : externalMainOutputs) {
emit(externalWriter, output);
}
}
@Override
public <T> void emit(final String dstVertexId, final T output) {
if (internalAdditionalOutputs.containsKey(dstVertexId)) {
for (final NextIntraTaskOperatorInfo internalVertex : internalAdditionalOutputs.get(dstVertexId)) {
emit(internalVertex.getNextOperator(), (O) output);
}
}
if (externalAdditionalOutputs.containsKey(dstVertexId)) {
for (final OutputWriter externalWriter : externalAdditionalOutputs.get(dstVertexId)) {
emit(externalWriter, (O) output);
}
}
}
@Override
public void emitWatermark(final Watermark watermark) {
if (LOG.isDebugEnabled()) {
LOG.debug("{} emits watermark {}", irVertex.getId(), watermark);
}
// Emit watermarks to internal vertices
for (final NextIntraTaskOperatorInfo internalVertex : internalMainOutputs) {
internalVertex.getWatermarkManager().trackAndEmitWatermarks(internalVertex.getEdgeIndex(), watermark);
}
for (final List<NextIntraTaskOperatorInfo> internalVertices : internalAdditionalOutputs.values()) {
for (final NextIntraTaskOperatorInfo internalVertex : internalVertices) {
internalVertex.getWatermarkManager().trackAndEmitWatermarks(internalVertex.getEdgeIndex(), watermark);
}
}
// Emit watermarks to output writer
for (final OutputWriter outputWriter : externalMainOutputs) {
outputWriter.writeWatermark(watermark);
}
for (final List<OutputWriter> externalVertices : externalAdditionalOutputs.values()) {
for (final OutputWriter externalVertex : externalVertices) {
externalVertex.writeWatermark(watermark);
}
}
}
}