0
나는 현재 Google tutorial

아파치 빔 틀 : 런타임 컨텍스트 오류

같은 아파치 빔 SDK의 V2.1.0를 기반으로 데이터 흐름 템플릿을 만들려고 해요

이는 경우 내 메인 클래스

public static void main(String[] args) { 

    // Initialize options 
    DispatcherOptions options = PipelineOptionsFactory.fromArgs(args).withValidation().as(DispatcherOptions.class); 

    // Create pipeline 
    Pipeline pipeline = Pipeline.create(options); 

    // Get messages 
    PCollection<PubsubMessage> messages = pipeline.apply("ReadMain", PubsubIO.readMessages().fromSubscription(options.getSubscription())); 

    } 

입니다 I 나는이 방법을 사용하는 경우이 작업 년대

mvn compile exec:java \ 
-Dexec.mainClass=com.example.myclass \ 
-Dexec.args="--runner=DataflowRunner \ 
       --project=[YOUR_PROJECT_ID] \ 
       --stagingLocation=gs://[YOUR_BUCKET_NAME]/staging \ 
       --templateLocation=gs://[YOUR_BUCKET_NAME]/templates/MyTemplate" 

명령을 실행

,

하지만

PubsubIO.readMessages().fromSubscription(options.getSubscription())); 

오류

[WARNING] 
java.lang.RuntimeException: Not called from a runtime context. 
    at org.apache.beam.sdk.options.ValueProvider$RuntimeValueProvider.get(ValueProvider.java:223) 
    at org.apache.beam.sdk.options.ValueProvider$NestedValueProvider.get(ValueProvider.java:131) 
    at org.apache.beam.sdk.options.ValueProvider$NestedValueProvider.get(ValueProvider.java:131) 
    at org.apache.beam.sdk.io.gcp.pubsub.PubsubUnboundedSource.getSubscription(PubsubUnboundedSource.java:1374) 
    at org.apache.beam.sdk.io.gcp.pubsub.PubsubUnboundedSource$PubsubSource.<init>(PubsubUnboundedSource.java:1103) 
    at org.apache.beam.sdk.io.gcp.pubsub.PubsubUnboundedSource.expand(PubsubUnboundedSource.java:1407) 
    at org.apache.beam.sdk.io.gcp.pubsub.PubsubUnboundedSource.expand(PubsubUnboundedSource.java:110) 
    at org.apache.beam.sdk.Pipeline.applyInternal(Pipeline.java:514) 
    at org.apache.beam.sdk.Pipeline.applyTransform(Pipeline.java:454) 
    at org.apache.beam.sdk.values.PBegin.apply(PBegin.java:44) 
    at org.apache.beam.sdk.io.gcp.pubsub.PubsubIO$Read.expand(PubsubIO.java:730) 
    at org.apache.beam.sdk.io.gcp.pubsub.PubsubIO$Read.expand(PubsubIO.java:536) 
    at org.apache.beam.sdk.Pipeline.applyInternal(Pipeline.java:514) 
    at org.apache.beam.sdk.Pipeline.applyTransform(Pipeline.java:473) 
    at org.apache.beam.sdk.values.PBegin.apply(PBegin.java:56) 
    at org.apache.beam.sdk.Pipeline.apply(Pipeline.java:180) 
    at com.example.myclass.main(MyClass.java:43) 
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) 
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
    at java.lang.reflect.Method.invoke(Method.java:498) 
    at org.codehaus.mojo.exec.ExecJavaMojo$1.run(ExecJavaMojo.java:282) 
    at java.lang.Thread.run(Thread.java:748) 

답변

1

이 PubSubIO의 구현에 벌레처럼 보이는 경우. 이 문제를 추적하려면 https://issues.apache.org/jira/browse/BEAM-2982을 생성했습니다.

+0

패치를 사용할 수 있으며 작동합니다. fromSubscription과 함께 템플릿을 사용할 수 있습니다. –