public interface Service extends Serializable
IgniteServices
facade or directly from grid configuration at startup.
execute()
method on that service. It is up to the user
to control whenever the service should exit from the execute
method.
For example, user may choose to implement service as follows:
public class MyIgniteService implements Service { ... // Example of ignite resource injection. All resources are optional. // You should inject resources only as needed. @IgniteInstanceResource private Ignite ignite; @ServiceContextResource private ServiceContext ctx; ... @Override public void cancel() { // No-op. } @Override public void execute() { // Loop until service is cancelled. while (!ctx.isCancelled()) { // Do something. ... } } }Consecutively, this service can be deployed as follows:
... IgniteServices svcs = ignite.services(); svcs.deployClusterSingleton("mySingleton", new MyIgniteService());Or from grid configuration on startup:
IgniteConfiguration gridCfg = new IgniteConfiguration(); IgniteServiceConfiguration svcCfg = new IgniteServiceConfiguration(); // Configuration for cluster-singleton service. svcCfg.setName("mySingleton"); svcCfg.setMaxPerNodeCount(1); svcCfg.setTotalCount(1); svcCfg.setService(new MyIgniteService()); gridCfg.setServiceConfiguration(svcCfg); ... Ignition.start(gridCfg);
cancel
methods on IgniteServices
API.
Whenever a deployed service is cancelled, Ignite will automatically call
cancel()
method on that service.
Note that Ignite cannot guarantee that the service exits from execute()
method whenever cancel()
is called. It is up to the user to
make sure that the service code properly reacts to cancellations.
Modifier and Type | Method and Description |
---|---|
default void |
cancel()
Cancels this service.
|
default void |
cancel(ServiceContext ctx)
Deprecated.
Use
cancel() instead. |
default void |
execute()
Starts execution of this service.
|
default void |
execute(ServiceContext ctx)
Deprecated.
Use
execute() instead. |
default void |
init()
Pre-initializes service before execution.
|
default void |
init(ServiceContext ctx)
Deprecated.
Use
init() instead. |
default void cancel()
cancel
methods on IgniteServices
API are called.
Note that Ignite cannot guarantee that the service exits from execute()
method whenever cancel()
method is called. It is up to the user to
make sure that the service code properly reacts to cancellations.
ServiceContextResource
default void init() throws Exception
execute()
is called).Exception
- If service initialization failed.ServiceContextResource
default void execute() throws Exception
execute
method and can be cancelled (or undeployed) only by calling any of the cancel
methods on
IgniteServices
API. Also note that service is not required to exit from execute
method until
cancel()
method was called.Exception
- If service execution failed. Not that service will still remain deployed, until
IgniteServices.cancel(String)
method will be called.ServiceContextResource
@Deprecated default void cancel(ServiceContext ctx)
cancel()
instead.cancel
methods on IgniteServices
API are called.
Note that Ignite cannot guarantee that the service exits from execute(ServiceContext)
method whenever cancel(ServiceContext)
method is called. It is up to the user to
make sure that the service code properly reacts to cancellations.
ctx
- Service execution context.@Deprecated default void init(ServiceContext ctx) throws Exception
init()
instead.execute(ServiceContext)
is called).ctx
- Service execution context.Exception
- If service initialization failed.@Deprecated default void execute(ServiceContext ctx) throws Exception
execute()
instead.execute
method and can be cancelled (or undeployed) only by calling any of the cancel
methods on
IgniteServices
API. Also note that service is not required to exit from execute
method until
cancel(ServiceContext)
method was called.ctx
- Service execution context.Exception
- If service execution failed. Not that service will still remain deployed, until
IgniteServices.cancel(String)
method will be called.
Follow @ApacheIgnite
Ignite Database and Caching Platform : ver. 2.16.0 Release Date : December 15 2023