public interface RuntimeManagerRuntimeManager manages
RuntimeEngines that are essentially build with
TaskServiceto deliver executable environments for processes and user tasks.
RuntimeManagerensures that all components are configured and bootstrapped as soon as manager is instantiated to ensure its fully featured functionality right from the start. That includes:
- timer service
- task service
- finds and initializes timer start events based processes
RuntimeManagers are identified by unique identifiers and thus there cannot be two RuntimeManagers with the same id active at the same time in the same system.
RuntimeManager implements runtime strategy that provides certain management capabilities to reduce manual work needed to control ksession behavior. Which mainly covers when to create, dispose and when to use which ksession. Currently there are three predefined strategies:
- Singleton - there is only one, always active ksession for the manager, access to it is thread safe that is achieved by synchronization which applies to both ksession and task service
- PerRequest - new ksession and task service instances will be returned for every invocation of the getRuntimeEngine(Context) method. Important to know is same instance of RuntimeEngine will be returned through out transaction to avoid issues with persistence context.
- PerProcessInstance - most advanced strategy that keeps track of which ksession was used to work with given process instance. It lives as long as process instance is alive and is destroyed when process instance is completed/aborted.
All Methods Instance Methods Abstract Methods Modifier and Type Method Description
RuntimeManagerand releases it's resources.
RuntimeEngineand notifies all listeners about that fact.
RuntimeEngineinstance that is fully initialized: KiseSession is created or loaded depending on the strategy TaskService is initialized and attached to ksession (via listener) WorkItemHandlers are initialized and registered on ksession EventListeners (process, agenda, working memory) are initialized and added to ksession
signalEvent(String type, Object event)Allows to signal event on runtime manager level which in turn allows to broadcast given event to all listening components managed by this RuntimeManager
RuntimeEngine getRuntimeEngine(Context<?> context)
RuntimeEngineinstance that is fully initialized:
- KiseSession is created or loaded depending on the strategy
- TaskService is initialized and attached to ksession (via listener)
- WorkItemHandlers are initialized and registered on ksession
- EventListeners (process, agenda, working memory) are initialized and added to ksession
context- the concrete implementation of the context that is supported by given
- instance of the
- unique identifier of this
void disposeRuntimeEngine(RuntimeEngine runtime)Disposes
RuntimeEngineand notifies all listeners about that fact. This method should always be used to dispose
RuntimeEnginethat is not needed anymore.
ksession.dispose() shall never be used with RuntimeManager as it will break the internal mechanisms of the manager responsible for clear and efficient disposal.
Dispose is not needed if
RuntimeEnginewas obtained within active JTA transaction, this means that when getRuntimeEngine method was invoked during active JTA transaction then dispose of the runtime engine will happen automatically on transaction completion.
RuntimeManagerand releases it's resources. Shall always be called when runtime manager is not needed any more. Otherwise it will still be active and operational.