public class SdkHarnessClient.BundleProcessor
extends java.lang.Object
BeamFnApi.ProcessBundleDescriptor
.Modifier and Type | Class and Description |
---|---|
class |
SdkHarnessClient.BundleProcessor.ActiveBundle
An active bundle for a particular
BeamFnApi.ProcessBundleDescriptor . |
Modifier and Type | Method and Description |
---|---|
java.util.concurrent.CompletionStage<org.apache.beam.model.fnexecution.v1.BeamFnApi.RegisterResponse> |
getRegistrationFuture() |
SdkHarnessClient.BundleProcessor.ActiveBundle |
newBundle(java.util.Map<java.lang.String,RemoteOutputReceiver<?>> outputReceivers,
BundleProgressHandler progressHandler)
Start a new bundle for the given
BeamFnApi.ProcessBundleDescriptor identifier. |
SdkHarnessClient.BundleProcessor.ActiveBundle |
newBundle(java.util.Map<java.lang.String,RemoteOutputReceiver<?>> outputReceivers,
java.util.Map<KV<java.lang.String,java.lang.String>,RemoteOutputReceiver<org.apache.beam.runners.core.construction.Timer<?>>> timerReceivers,
StateRequestHandler stateRequestHandler,
BundleProgressHandler progressHandler)
Start a new bundle for the given
BeamFnApi.ProcessBundleDescriptor identifier. |
SdkHarnessClient.BundleProcessor.ActiveBundle |
newBundle(java.util.Map<java.lang.String,RemoteOutputReceiver<?>> outputReceivers,
java.util.Map<KV<java.lang.String,java.lang.String>,RemoteOutputReceiver<org.apache.beam.runners.core.construction.Timer<?>>> timerReceivers,
StateRequestHandler stateRequestHandler,
BundleProgressHandler progressHandler,
BundleSplitHandler splitHandler,
BundleCheckpointHandler checkpointHandler,
BundleFinalizationHandler finalizationHandler)
Start a new bundle for the given
BeamFnApi.ProcessBundleDescriptor identifier. |
SdkHarnessClient.BundleProcessor.ActiveBundle |
newBundle(java.util.Map<java.lang.String,RemoteOutputReceiver<?>> outputReceivers,
StateRequestHandler stateRequestHandler,
BundleProgressHandler progressHandler)
Start a new bundle for the given
BeamFnApi.ProcessBundleDescriptor identifier. |
public java.util.concurrent.CompletionStage<org.apache.beam.model.fnexecution.v1.BeamFnApi.RegisterResponse> getRegistrationFuture()
public SdkHarnessClient.BundleProcessor.ActiveBundle newBundle(java.util.Map<java.lang.String,RemoteOutputReceiver<?>> outputReceivers, BundleProgressHandler progressHandler)
BeamFnApi.ProcessBundleDescriptor
identifier.
The input channels for the returned SdkHarnessClient.BundleProcessor.ActiveBundle
are derived from the instructions
in the BeamFnApi.ProcessBundleDescriptor
.
NOTE: It is important to SdkHarnessClient.close()
each bundle after all elements are emitted.
try (ActiveBundle bundle = SdkHarnessClient.newBundle(...)) {
FnDataReceiver<InputT> inputReceiver =
(FnDataReceiver) bundle.getInputReceivers().get(mainPCollectionId);
// send all main input elements ...
}
An exception during SdkHarnessClient.close()
will be thrown if the bundle requests finalization or
attempts to checkpoint by returning a BeamFnApi.DelayedBundleApplication
.
public SdkHarnessClient.BundleProcessor.ActiveBundle newBundle(java.util.Map<java.lang.String,RemoteOutputReceiver<?>> outputReceivers, StateRequestHandler stateRequestHandler, BundleProgressHandler progressHandler)
BeamFnApi.ProcessBundleDescriptor
identifier.
The input channels for the returned SdkHarnessClient.BundleProcessor.ActiveBundle
are derived from the instructions
in the BeamFnApi.ProcessBundleDescriptor
.
NOTE: It is important to SdkHarnessClient.close()
each bundle after all elements are emitted.
try (ActiveBundle bundle = SdkHarnessClient.newBundle(...)) {
FnDataReceiver<InputT> inputReceiver =
(FnDataReceiver) bundle.getInputReceivers().get(mainPCollectionId);
// send all main input elements ...
}
An exception during SdkHarnessClient.close()
will be thrown if the bundle requests finalization or
attempts to checkpoint by returning a BeamFnApi.DelayedBundleApplication
.
public SdkHarnessClient.BundleProcessor.ActiveBundle newBundle(java.util.Map<java.lang.String,RemoteOutputReceiver<?>> outputReceivers, java.util.Map<KV<java.lang.String,java.lang.String>,RemoteOutputReceiver<org.apache.beam.runners.core.construction.Timer<?>>> timerReceivers, StateRequestHandler stateRequestHandler, BundleProgressHandler progressHandler)
BeamFnApi.ProcessBundleDescriptor
identifier.
The input channels for the returned SdkHarnessClient.BundleProcessor.ActiveBundle
are derived from the instructions
in the BeamFnApi.ProcessBundleDescriptor
.
NOTE: It is important to SdkHarnessClient.close()
each bundle after all elements are emitted.
try (ActiveBundle bundle = SdkHarnessClient.newBundle(...)) {
FnDataReceiver<InputT> inputReceiver =
(FnDataReceiver) bundle.getInputReceivers().get(mainPCollectionId);
// send all main input elements ...
}
An exception during SdkHarnessClient.close()
will be thrown if the bundle requests finalization or
attempts to checkpoint by returning a BeamFnApi.DelayedBundleApplication
.
public SdkHarnessClient.BundleProcessor.ActiveBundle newBundle(java.util.Map<java.lang.String,RemoteOutputReceiver<?>> outputReceivers, java.util.Map<KV<java.lang.String,java.lang.String>,RemoteOutputReceiver<org.apache.beam.runners.core.construction.Timer<?>>> timerReceivers, StateRequestHandler stateRequestHandler, BundleProgressHandler progressHandler, BundleSplitHandler splitHandler, BundleCheckpointHandler checkpointHandler, BundleFinalizationHandler finalizationHandler)
BeamFnApi.ProcessBundleDescriptor
identifier.
The input channels for the returned SdkHarnessClient.BundleProcessor.ActiveBundle
are derived from the instructions
in the BeamFnApi.ProcessBundleDescriptor
.
NOTE: It is important to SdkHarnessClient.close()
each bundle after all elements are emitted.
try (ActiveBundle bundle = SdkHarnessClient.newBundle(...)) {
FnDataReceiver<InputT> inputReceiver =
(FnDataReceiver) bundle.getInputReceivers().get(mainPCollectionId);
// send all elements ...
}