当前位置: 首页>>代码示例>>Java>>正文


Java Pipeline.traverseTopologically方法代码示例

本文整理汇总了Java中org.apache.beam.sdk.Pipeline.traverseTopologically方法的典型用法代码示例。如果您正苦于以下问题:Java Pipeline.traverseTopologically方法的具体用法?Java Pipeline.traverseTopologically怎么用?Java Pipeline.traverseTopologically使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在org.apache.beam.sdk.Pipeline的用法示例。


在下文中一共展示了Pipeline.traverseTopologically方法的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。

示例1: ensureAllReadsConsumed

import org.apache.beam.sdk.Pipeline; //导入方法依赖的package包/类
public static void ensureAllReadsConsumed(Pipeline pipeline) {
  final Set<PCollection<?>> unconsumed = new HashSet<>();
  pipeline.traverseTopologically(
      new PipelineVisitor.Defaults() {
        @Override
        public void visitPrimitiveTransform(Node node) {
          unconsumed.removeAll(node.getInputs().values());
        }

        @Override
        public void visitValue(PValue value, Node producer) {
          if (producer.getTransform() instanceof Read.Bounded
              || producer.getTransform() instanceof Read.Unbounded) {
            unconsumed.add((PCollection<?>) value);
          }
        }
      });
  int i = 0;
  for (PCollection<?> unconsumedPCollection : unconsumed) {
    consume(unconsumedPCollection, i);
    i++;
  }
}
 
开发者ID:apache,项目名称:beam,代码行数:24,代码来源:UnconsumedReads.java

示例2: testTrackSingle

import org.apache.beam.sdk.Pipeline; //导入方法依赖的package包/类
@Test
public void testTrackSingle() {
  options.setRunner(SparkRunner.class);
  JavaSparkContext jsc = SparkContextFactory.getSparkContext(options);
  JavaStreamingContext jssc = new JavaStreamingContext(jsc,
      new org.apache.spark.streaming.Duration(options.getBatchIntervalMillis()));

  Pipeline p = Pipeline.create(options);

  CreateStream<Integer> emptyStream =
      CreateStream.of(
          VarIntCoder.of(),
          Duration.millis(options.getBatchIntervalMillis())).emptyBatch();

  p.apply(emptyStream).apply(ParDo.of(new PassthroughFn<>()));

  p.traverseTopologically(new StreamingSourceTracker(jssc, p, ParDo.MultiOutput.class,  0));
  assertThat(StreamingSourceTracker.numAssertions, equalTo(1));
}
 
开发者ID:apache,项目名称:beam,代码行数:20,代码来源:TrackStreamingSourcesTest.java

示例3: testWorkerMachineTypeConfig

import org.apache.beam.sdk.Pipeline; //导入方法依赖的package包/类
@Test
public void testWorkerMachineTypeConfig() throws IOException {
  final String testMachineType = "test-machine-type";

  DataflowPipelineOptions options = buildPipelineOptions();
  options.setWorkerMachineType(testMachineType);

  Pipeline p = buildPipeline(options);
  p.traverseTopologically(new RecordingPipelineVisitor());
  Job job =
      DataflowPipelineTranslator.fromOptions(options)
          .translate(
              p, DataflowRunner.fromOptions(options), Collections.<DataflowPackage>emptyList())
          .getJob();

  assertEquals(1, job.getEnvironment().getWorkerPools().size());

  WorkerPool workerPool = job.getEnvironment().getWorkerPools().get(0);
  assertEquals(testMachineType, workerPool.getMachineType());
}
 
开发者ID:apache,项目名称:beam,代码行数:21,代码来源:DataflowPipelineTranslatorTest.java

示例4: testApplyIsScopedToExactClass

import org.apache.beam.sdk.Pipeline; //导入方法依赖的package包/类
@Test
public void testApplyIsScopedToExactClass() throws IOException {
  DataflowPipelineOptions options = buildPipelineOptions();
  Pipeline p = Pipeline.create(options);

  Create.TimestampedValues<String> transform =
      Create.timestamped(Arrays.asList(TimestampedValue.of("TestString", Instant.now())));
  p.apply(transform);

  CompositeTransformRecorder recorder = new CompositeTransformRecorder();
  p.traverseTopologically(recorder);

  // The recorder will also have seen a Create.Values composite as well, but we can't obtain that
  // transform.
  assertThat(
      "Expected to have seen CreateTimestamped composite transform.",
      recorder.getCompositeTransforms(),
      hasItem(transform));
  assertThat(
      "Expected to have two composites, CreateTimestamped and Create.Values",
      recorder.getCompositeTransforms(),
      hasItem(Matchers.<PTransform<?, ?>>isA((Class) Create.Values.class)));
}
 
开发者ID:apache,项目名称:beam,代码行数:24,代码来源:DataflowRunnerTest.java

示例5: testDiskSizeGbConfig

import org.apache.beam.sdk.Pipeline; //导入方法依赖的package包/类
@Test
public void testDiskSizeGbConfig() throws IOException {
  final Integer diskSizeGb = 1234;

  DataflowPipelineOptions options = buildPipelineOptions();
  options.setDiskSizeGb(diskSizeGb);

  Pipeline p = buildPipeline(options);
  p.traverseTopologically(new RecordingPipelineVisitor());
  Job job =
      DataflowPipelineTranslator.fromOptions(options)
          .translate(
              p, DataflowRunner.fromOptions(options), Collections.<DataflowPackage>emptyList())
          .getJob();

  assertEquals(1, job.getEnvironment().getWorkerPools().size());
  assertEquals(diskSizeGb,
      job.getEnvironment().getWorkerPools().get(0).getDiskSizeGb());
}
 
开发者ID:apache,项目名称:beam,代码行数:20,代码来源:DataflowPipelineTranslatorTest.java

示例6: testSubnetworkConfig

import org.apache.beam.sdk.Pipeline; //导入方法依赖的package包/类
@Test
public void testSubnetworkConfig() throws IOException {
  final String testSubnetwork = "regions/REGION/subnetworks/SUBNETWORK";

  DataflowPipelineOptions options = buildPipelineOptions();
  options.setSubnetwork(testSubnetwork);

  Pipeline p = buildPipeline(options);
  p.traverseTopologically(new RecordingPipelineVisitor());
  Job job =
      DataflowPipelineTranslator.fromOptions(options)
          .translate(
              p, DataflowRunner.fromOptions(options), Collections.<DataflowPackage>emptyList())
          .getJob();

  assertEquals(1, job.getEnvironment().getWorkerPools().size());
  assertEquals(testSubnetwork,
      job.getEnvironment().getWorkerPools().get(0).getSubnetwork());
}
 
开发者ID:apache,项目名称:beam,代码行数:20,代码来源:DataflowPipelineTranslatorTest.java

示例7: isStreaming

import org.apache.beam.sdk.Pipeline; //导入方法依赖的package包/类
public boolean isStreaming(Pipeline pipeline) {
  if(options.isStreaming()) {
    return true;
  }

  pipeline.traverseTopologically(this);

  return streaming;
}
 
开发者ID:FreshetDMS,项目名称:Freshet-Deprecated,代码行数:10,代码来源:PipelineModeDetector.java

示例8: testSubnetworkConfigMissing

import org.apache.beam.sdk.Pipeline; //导入方法依赖的package包/类
@Test
public void testSubnetworkConfigMissing() throws IOException {
  DataflowPipelineOptions options = buildPipelineOptions();

  Pipeline p = buildPipeline(options);
  p.traverseTopologically(new RecordingPipelineVisitor());
  Job job =
      DataflowPipelineTranslator.fromOptions(options)
          .translate(
              p, DataflowRunner.fromOptions(options), Collections.<DataflowPackage>emptyList())
          .getJob();

  assertEquals(1, job.getEnvironment().getWorkerPools().size());
  assertNull(job.getEnvironment().getWorkerPools().get(0).getSubnetwork());
}
 
开发者ID:apache,项目名称:beam,代码行数:16,代码来源:DataflowPipelineTranslatorTest.java

示例9: testProtoAgainstRehydrated

import org.apache.beam.sdk.Pipeline; //导入方法依赖的package包/类
@Test
public void testProtoAgainstRehydrated() throws Exception {
  RunnerApi.Pipeline pipelineProto = PipelineTranslation.toProto(pipeline);
  Pipeline rehydrated = PipelineTranslation.fromProto(pipelineProto);

  rehydrated.traverseTopologically(
      new PipelineProtoVerificationVisitor(pipelineProto));
}
 
开发者ID:apache,项目名称:beam,代码行数:9,代码来源:PipelineTranslationTest.java

示例10: testScalingAlgorithmMissing

import org.apache.beam.sdk.Pipeline; //导入方法依赖的package包/类
@Test
public void testScalingAlgorithmMissing() throws IOException {
  DataflowPipelineOptions options = buildPipelineOptions();

  Pipeline p = buildPipeline(options);
  p.traverseTopologically(new RecordingPipelineVisitor());
  Job job =
      DataflowPipelineTranslator.fromOptions(options)
          .translate(
              p, DataflowRunner.fromOptions(options), Collections.<DataflowPackage>emptyList())
          .getJob();

  assertEquals(1, job.getEnvironment().getWorkerPools().size());
  // Autoscaling settings are always set.
  assertNull(
      job
          .getEnvironment()
          .getWorkerPools()
          .get(0)
          .getAutoscalingSettings()
          .getAlgorithm());
  assertEquals(
      0,
      job
          .getEnvironment()
          .getWorkerPools()
          .get(0)
          .getAutoscalingSettings()
          .getMaxNumWorkers()
          .intValue());
}
 
开发者ID:apache,项目名称:beam,代码行数:32,代码来源:DataflowPipelineTranslatorTest.java

示例11: translate

import org.apache.beam.sdk.Pipeline; //导入方法依赖的package包/类
public void translate(Pipeline pipeline) {
  List<PTransformOverride> overrides =
      ImmutableList.<PTransformOverride>builder()
          .add(PTransformOverride.of(
              PTransformMatchers.classEqualTo(View.CreatePCollectionView.class),
              new CreateStreamingGearpumpView.Factory()))
          .build();

  pipeline.replaceAll(overrides);
  pipeline.traverseTopologically(this);
}
 
开发者ID:apache,项目名称:beam,代码行数:12,代码来源:GearpumpPipelineTranslator.java

示例12: testMaxNumWorkersIsPassedWhenNoAlgorithmIsSet

import org.apache.beam.sdk.Pipeline; //导入方法依赖的package包/类
@Test
public void testMaxNumWorkersIsPassedWhenNoAlgorithmIsSet() throws IOException {
  final DataflowPipelineWorkerPoolOptions.AutoscalingAlgorithmType noScaling = null;
  DataflowPipelineOptions options = buildPipelineOptions();
  options.setMaxNumWorkers(42);
  options.setAutoscalingAlgorithm(noScaling);

  Pipeline p = buildPipeline(options);
  p.traverseTopologically(new RecordingPipelineVisitor());
  Job job =
      DataflowPipelineTranslator.fromOptions(options)
          .translate(
              p, DataflowRunner.fromOptions(options), Collections.<DataflowPackage>emptyList())
          .getJob();

  assertEquals(1, job.getEnvironment().getWorkerPools().size());
  assertNull(
      job
          .getEnvironment()
          .getWorkerPools()
          .get(0)
          .getAutoscalingSettings()
          .getAlgorithm());
  assertEquals(
      42,
      job
          .getEnvironment()
          .getWorkerPools()
          .get(0)
          .getAutoscalingSettings()
          .getMaxNumWorkers()
          .intValue());
}
 
开发者ID:apache,项目名称:beam,代码行数:34,代码来源:DataflowPipelineTranslatorTest.java

示例13: testNetworkConfigMissing

import org.apache.beam.sdk.Pipeline; //导入方法依赖的package包/类
@Test
public void testNetworkConfigMissing() throws IOException {
  DataflowPipelineOptions options = buildPipelineOptions();

  Pipeline p = buildPipeline(options);
  p.traverseTopologically(new RecordingPipelineVisitor());
  Job job =
      DataflowPipelineTranslator.fromOptions(options)
          .translate(
              p, DataflowRunner.fromOptions(options), Collections.<DataflowPackage>emptyList())
          .getJob();

  assertEquals(1, job.getEnvironment().getWorkerPools().size());
  assertNull(job.getEnvironment().getWorkerPools().get(0).getNetwork());
}
 
开发者ID:apache,项目名称:beam,代码行数:16,代码来源:DataflowPipelineTranslatorTest.java

示例14: translate

import org.apache.beam.sdk.Pipeline; //导入方法依赖的package包/类
public SamzaPipelineSpecification translate(Pipeline pipeline) {
  pipeline.traverseTopologically(this);
  return samzaPipelineSpec;
}
 
开发者ID:FreshetDMS,项目名称:Freshet-Deprecated,代码行数:5,代码来源:SamzaPipelineTranslator.java

示例15: run

import org.apache.beam.sdk.Pipeline; //导入方法依赖的package包/类
@Override
public DirectPipelineResult run(Pipeline originalPipeline) {
  Pipeline pipeline;
  try {
    RunnerApi.Pipeline protoPipeline = PipelineTranslation.toProto(originalPipeline);
    pipeline = PipelineTranslation.fromProto(protoPipeline);
  } catch (IOException exception) {
    throw new RuntimeException("Error preparing pipeline for direct execution.", exception);
  }
  pipeline.replaceAll(defaultTransformOverrides());
  MetricsEnvironment.setMetricsSupported(true);
  DirectGraphVisitor graphVisitor = new DirectGraphVisitor();
  pipeline.traverseTopologically(graphVisitor);

  @SuppressWarnings("rawtypes")
  KeyedPValueTrackingVisitor keyedPValueVisitor = KeyedPValueTrackingVisitor.create();
  pipeline.traverseTopologically(keyedPValueVisitor);

  DisplayDataValidator.validatePipeline(pipeline);
  DisplayDataValidator.validateOptions(getPipelineOptions());

  DirectGraph graph = graphVisitor.getGraph();
  EvaluationContext context =
      EvaluationContext.create(
          getPipelineOptions(),
          clockSupplier.get(),
          Enforcement.bundleFactoryFor(enabledEnforcements, graph),
          graph,
          keyedPValueVisitor.getKeyedPValues());

  TransformEvaluatorRegistry registry = TransformEvaluatorRegistry.defaultRegistry(context);
  PipelineExecutor executor =
      ExecutorServiceParallelExecutor.create(
          options.getTargetParallelism(),
          registry,
          Enforcement.defaultModelEnforcements(enabledEnforcements),
          context);
  executor.start(graph, RootProviderRegistry.defaultRegistry(context));

  DirectPipelineResult result = new DirectPipelineResult(executor, context);
  if (options.isBlockOnRun()) {
    try {
      result.waitUntilFinish();
    } catch (UserCodeException userException) {
      throw new PipelineExecutionException(userException.getCause());
    } catch (Throwable t) {
      if (t instanceof RuntimeException) {
        throw (RuntimeException) t;
      }
      throw new RuntimeException(t);
    }
  }
  return result;
}
 
开发者ID:apache,项目名称:beam,代码行数:55,代码来源:DirectRunner.java


注:本文中的org.apache.beam.sdk.Pipeline.traverseTopologically方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。