@FunctionalInterface public interface ProcessorMetaSupplier extends Serializable
ProcessorSupplier
instances. The starting point of
the chain leading to the eventual creation of Processor
instances
on each cluster member:
ProcessorMetaSupplier
as a part of the DAG;
ProcessorSupplier
for each cluster member;
ProcessorSupplier
and sends it to its target member;
Processor
as requested by the parallelism property on
the corresponding Vertex
.
ProcessorSupplier
s this meta-supplier will
be given access to the Hazelcast instance and, in particular, its cluster topology
and partitioning services. It can use the information from these services to
precisely parameterize each Processor
instance that will be created on
each member.Modifier and Type | Interface and Description |
---|---|
static interface |
ProcessorMetaSupplier.Context
Context passed to the meta-supplier at init time on the member that
received a job request from the client.
|
Modifier and Type | Method and Description |
---|---|
default void |
close(Throwable error)
Called on coordinator member after execution has finished on all
members, successfully or not.
|
static ProcessorMetaSupplier |
forceTotalParallelismOne(ProcessorSupplier supplier)
Variant of
forceTotalParallelismOne(ProcessorSupplier, String, Permission)
where the node for the supplier will be chosen randomly and
without any required permission. |
static ProcessorMetaSupplier |
forceTotalParallelismOne(ProcessorSupplier supplier,
Address memberAddress)
Wraps the provided
ProcessorSupplier into a meta-supplier that
will only use the given ProcessorSupplier on a node with the
given Address . |
static ProcessorMetaSupplier |
forceTotalParallelismOne(ProcessorSupplier supplier,
Permission permission)
Variant of
forceTotalParallelismOne(ProcessorSupplier, String, Permission)
where the node for the supplier will be chosen randomly. |
static ProcessorMetaSupplier |
forceTotalParallelismOne(ProcessorSupplier supplier,
String partitionKey)
Variant of
forceTotalParallelismOne(ProcessorSupplier, String, Permission)
without any required permission. |
static ProcessorMetaSupplier |
forceTotalParallelismOne(ProcessorSupplier supplier,
String partitionKey,
Permission permission)
Wraps the provided
ProcessorSupplier into a meta-supplier that
will only use the given ProcessorSupplier on a single node. |
Function<? super Address,? extends ProcessorSupplier> |
get(List<Address> addresses)
Called to create a mapping from member
Address to the
ProcessorSupplier that will be sent to that member. |
default Permission |
getRequiredPermission()
Returns the required permission to execute the vertex which has
this ProcessorMetaSupplier.
|
default Map<String,String> |
getTags()
Returns the metadata on this supplier, a string-to-string map.
|
default void |
init(ProcessorMetaSupplier.Context context)
Called on the cluster member that receives the client request, after
deserializing the meta-supplier instance.
|
static ProcessorMetaSupplier |
of(FunctionEx<? super Address,? extends ProcessorSupplier> addressToSupplier)
Factory method that creates a
ProcessorMetaSupplier from the
supplied function that maps a cluster member address to a ProcessorSupplier . |
static ProcessorMetaSupplier |
of(int preferredLocalParallelism,
FunctionEx<? super Address,? extends ProcessorSupplier> addressToSupplier)
Factory method that creates a
ProcessorMetaSupplier from the
supplied function that maps a cluster member address to a ProcessorSupplier . |
static ProcessorMetaSupplier |
of(int preferredLocalParallelism,
Permission permission,
ProcessorSupplier procSupplier)
Factory method that wraps the given
ProcessorSupplier and
returns the same instance for each given Address . |
static ProcessorMetaSupplier |
of(int preferredLocalParallelism,
ProcessorSupplier procSupplier)
Variant of
of(int, Permission, ProcessorSupplier) where
the processor does not require any permission to run. |
static ProcessorMetaSupplier |
of(int preferredLocalParallelism,
SupplierEx<? extends Processor> procSupplier)
Factory method that wraps the given
Supplier<Processor>
and uses it as the supplier of all Processor instances. |
static ProcessorMetaSupplier |
of(Permission permission,
ProcessorSupplier procSupplier)
Wraps the provided
ProcessorSupplier into a meta-supplier that
will always return it. |
static ProcessorMetaSupplier |
of(ProcessorSupplier procSupplier)
Variant of
of(Permission, ProcessorSupplier) where
the processor does not require any permission to run. |
static ProcessorMetaSupplier |
of(SupplierEx<? extends Processor> procSupplier)
Factory method that wraps the given
Supplier<Processor>
and uses it as the supplier of all Processor instances. |
static ProcessorMetaSupplier |
preferLocalParallelismOne(Permission permission,
ProcessorSupplier supplier)
Variant of
preferLocalParallelismOne(ProcessorSupplier) where the
processor requires given permission to run. |
static ProcessorMetaSupplier |
preferLocalParallelismOne(Permission permission,
SupplierEx<? extends Processor> procSupplier)
Variant of
preferLocalParallelismOne(SupplierEx) where the
processor requires given permission to run. |
static ProcessorMetaSupplier |
preferLocalParallelismOne(ProcessorSupplier supplier)
Wraps the provided
ProcessorSupplier into a meta-supplier that
will always return it. |
static ProcessorMetaSupplier |
preferLocalParallelismOne(SupplierEx<? extends Processor> procSupplier)
Variant of
preferLocalParallelismOne(ProcessorSupplier) where
the supplied SupplierEx<Processor> will be
wrapped into a ProcessorSupplier . |
default int |
preferredLocalParallelism()
Returns the local parallelism the vertex should be configured with.
|
@Nullable default Permission getRequiredPermission()
@Nonnull default Map<String,String> getTags()
default int preferredLocalParallelism()
Vertex.LOCAL_PARALLELISM_USE_DEFAULT
.default void init(@Nonnull ProcessorMetaSupplier.Context context) throws Exception
Exception
@Nonnull Function<? super Address,? extends ProcessorSupplier> get(@Nonnull List<Address> addresses)
Address
to the
ProcessorSupplier
that will be sent to that member. Jet calls
this method with a list of all cluster members' addresses and the
returned function must be a mapping that returns a non-null value for
each given address.
The method will be called once per job execution on the job's
coordinator member. init()
will have already
been called.
default void close(@Nullable Throwable error) throws Exception
ProcessorSupplier.close(Throwable)
has been called on all
available members. The job can be restarted later.
If there is an exception during the creation of the execution plan, this
method will be called regardless of whether the init()
or get()
method have been called or not.
If this method throws an exception, it will be logged and ignored; it
won't be reported as a job failure.
If you rely on the fact that this method is run once per cluster, it can happen that it is not called at all, if the coordinator member crashed. It can be also called multiple times, if the job restarts.
error
- the exception (if any) that caused the job to fail;
null
in the case of successful job completion.
Note that it might not be the actual error that caused the job
to fail - it can be several other exceptions. We only guarantee
that it's non-null if the job didn't complete successfully.Exception
@Nonnull static ProcessorMetaSupplier of(int preferredLocalParallelism, @Nullable Permission permission, @Nonnull ProcessorSupplier procSupplier)
ProcessorSupplier
and
returns the same instance for each given Address
.preferredLocalParallelism
- the value to return from preferredLocalParallelism()
permission
- the required permission to run the processorprocSupplier
- the processor supplier@Nonnull static ProcessorMetaSupplier of(int preferredLocalParallelism, @Nonnull ProcessorSupplier procSupplier)
of(int, Permission, ProcessorSupplier)
where
the processor does not require any permission to run.@Nonnull static ProcessorMetaSupplier of(@Nullable Permission permission, @Nonnull ProcessorSupplier procSupplier)
ProcessorSupplier
into a meta-supplier that
will always return it. The preferredLocalParallelism()
of
the meta-supplier will be Vertex.LOCAL_PARALLELISM_USE_DEFAULT
.@Nonnull static ProcessorMetaSupplier of(@Nonnull ProcessorSupplier procSupplier)
of(Permission, ProcessorSupplier)
where
the processor does not require any permission to run.@Nonnull static ProcessorMetaSupplier of(int preferredLocalParallelism, @Nonnull SupplierEx<? extends Processor> procSupplier)
Supplier<Processor>
and uses it as the supplier of all Processor
instances.
Specifically, returns a meta-supplier that will always return the
result of calling ProcessorSupplier.of(SupplierEx)
.preferredLocalParallelism
- the value to return from preferredLocalParallelism()
procSupplier
- the supplier of processors@Nonnull static ProcessorMetaSupplier of(@Nonnull SupplierEx<? extends Processor> procSupplier)
Supplier<Processor>
and uses it as the supplier of all Processor
instances.
Specifically, returns a meta-supplier that will always return the
result of calling ProcessorSupplier.of(SupplierEx)
.
The preferredLocalParallelism()
of the meta-supplier will be
Vertex.LOCAL_PARALLELISM_USE_DEFAULT
.@Nonnull static ProcessorMetaSupplier of(int preferredLocalParallelism, @Nonnull FunctionEx<? super Address,? extends ProcessorSupplier> addressToSupplier)
ProcessorMetaSupplier
from the
supplied function that maps a cluster member address to a ProcessorSupplier
.preferredLocalParallelism
- the value to return from preferredLocalParallelism()
addressToSupplier
- the mapping from address to ProcessorSupplier@Nonnull static ProcessorMetaSupplier of(@Nonnull FunctionEx<? super Address,? extends ProcessorSupplier> addressToSupplier)
ProcessorMetaSupplier
from the
supplied function that maps a cluster member address to a ProcessorSupplier
. The preferredLocalParallelism()
of
the meta-supplier will be Vertex.LOCAL_PARALLELISM_USE_DEFAULT
.@Nonnull static ProcessorMetaSupplier preferLocalParallelismOne(@Nonnull ProcessorSupplier supplier)
ProcessorSupplier
into a meta-supplier that
will always return it. The preferredLocalParallelism()
of
the meta-supplier will be one, i.e., no local parallelization.
The parallelism will be overridden if the Vertex.localParallelism(int)
is
set to a specific value.
@Nonnull static ProcessorMetaSupplier preferLocalParallelismOne(@Nullable Permission permission, @Nonnull ProcessorSupplier supplier)
preferLocalParallelismOne(ProcessorSupplier)
where the
processor requires given permission to run.@Nonnull static ProcessorMetaSupplier preferLocalParallelismOne(@Nonnull SupplierEx<? extends Processor> procSupplier)
preferLocalParallelismOne(ProcessorSupplier)
where
the supplied SupplierEx<Processor>
will be
wrapped into a ProcessorSupplier
.@Nonnull static ProcessorMetaSupplier preferLocalParallelismOne(@Nullable Permission permission, @Nonnull SupplierEx<? extends Processor> procSupplier)
preferLocalParallelismOne(SupplierEx)
where the
processor requires given permission to run.@Nonnull static ProcessorMetaSupplier forceTotalParallelismOne(@Nonnull ProcessorSupplier supplier, @Nullable Permission permission)
forceTotalParallelismOne(ProcessorSupplier, String, Permission)
where the node for the supplier will be chosen randomly.@Nonnull static ProcessorMetaSupplier forceTotalParallelismOne(@Nonnull ProcessorSupplier supplier)
forceTotalParallelismOne(ProcessorSupplier, String, Permission)
where the node for the supplier will be chosen randomly and
without any required permission.@Nonnull static ProcessorMetaSupplier forceTotalParallelismOne(@Nonnull ProcessorSupplier supplier, @Nonnull String partitionKey)
forceTotalParallelismOne(ProcessorSupplier, String, Permission)
without any required permission.@Nonnull static ProcessorMetaSupplier forceTotalParallelismOne(@Nonnull ProcessorSupplier supplier, @Nonnull String partitionKey, @Nullable Permission permission)
ProcessorSupplier
into a meta-supplier that
will only use the given ProcessorSupplier
on a single node.
The node will be chosen according to the partitionKey
supplied.
This is mainly provided as a convenience for implementing
non-distributed sources where data can't be read in parallel by multiple
consumers. When used as a sink or intermediate vertex, the DAG should ensure
that only the processor instance on the designated node receives any data,
otherwise an IllegalStateException
will be thrown.
The vertex containing the ProcessorMetaSupplier
must have a local
parallelism setting of 1, otherwise {code IllegalArgumentException} is thrown.
supplier
- the supplier that will be wrappedpartitionKey
- the supplier will only be created on the node that owns the supplied
partition keypermission
- the required permission to run the processorProcessorMetaSupplier
IllegalArgumentException
- if vertex has local parallelism setting of greater than 1@Nonnull static ProcessorMetaSupplier forceTotalParallelismOne(@Nonnull ProcessorSupplier supplier, @Nonnull Address memberAddress)
ProcessorSupplier
into a meta-supplier that
will only use the given ProcessorSupplier
on a node with the
given Address
. This is mainly provided as a convenience for
implementing non-distributed sources where data can't be read in
parallel by multiple consumers. When used as a sink or intermediate
vertex, the DAG should ensure that only the processor instance on the
designated node receives any data, otherwise an IllegalStateException
will be thrown.
The vertex containing the ProcessorMetaSupplier
must have a
local parallelism setting of 1, otherwise {code
IllegalArgumentException} is thrown.
supplier
- the supplier that will be wrappedmemberAddress
- the supplier will only be created on the node with given Address
ProcessorMetaSupplier
IllegalArgumentException
- if vertex has local parallelism setting of greater than 1Copyright © 2022 Hazelcast, Inc.. All rights reserved.