Class TwoPhaseBootstrap<T extends ADEPT2Service>
- java.lang.Object
- 
- de.aristaflow.adept2.base.service.AbstractADEPT2Service
- 
- de.aristaflow.adept2.base.service.AbstractAuthenticatedService
- 
- de.aristaflow.adept2.base.registry.AbstractRegistry
- 
- de.aristaflow.adept2.base.registry.PluginRegistry
- 
- de.aristaflow.adept2.base.registry.InstanceToInstanceRegistry
- 
- de.aristaflow.adept2.base.registry.LocalServiceRegistry
- 
- de.aristaflow.adept2.base.registry.ServiceRegistry
- 
- de.aristaflow.adept2.core.registry.BootstrapRegistry
- 
- de.aristaflow.adept2.core.registry.twophase.TwoPhaseBootstrap<T>
 
 
 
 
 
 
 
 
 
- 
- Type Parameters:
- T- The type of the initial service which is provided after the first phase of bootstrapping.
 - All Implemented Interfaces:
- GlobalInvocationResolver,- GlobalRegistryServiceProvider,- ConfMgrRegistry,- ADEPT2Service,- AuthenticatingService,- LogService,- NameResolution,- ServiceThreadHandling
 
 public class TwoPhaseBootstrap<T extends ADEPT2Service> extends BootstrapRegistry A bootstrap registry that bootstraps and shuts down in two phases. First the registry is only bootstrapped to retrieve the initial service provided in the constructor. Afterwards the second phase of bootstrapping may continue at any time. Note that the second phase is required before accessing the registry.
 The first phase just starts the initial service as well as its required services. Note that the registry cannot be accessed in the first phase since it is not (completely) started. So only basic services may be started in the first phase.
 Shutting down may also consist of two inverse phases by usingshutdownToInitialService()andBootstrapRegistry.shutdown(boolean). Shutting down may also be done in one step by just callingBootstrapRegistry.shutdown(boolean). Be sure to callBootstrapRegistry.shutdown(boolean)in afinally-clause so that it will be done under all circumstances.If no initial service is provided, this registry will just act like the BootstrapRegistry, that is first and second phase will be one phase.
- 
- 
Nested Class Summary- 
Nested classes/interfaces inherited from class de.aristaflow.adept2.base.registry.ServiceRegistryServiceRegistry.ConfigurationValidator
 - 
Nested classes/interfaces inherited from class de.aristaflow.adept2.base.registry.LocalServiceRegistryLocalServiceRegistry.ServiceExportInformation, LocalServiceRegistry.ServiceNameResolution, LocalServiceRegistry.ServiceStarter
 - 
Nested classes/interfaces inherited from class de.aristaflow.adept2.base.registry.PluginRegistryPluginRegistry.URLClassloaderPrivilegedAction
 - 
Nested classes/interfaces inherited from class de.aristaflow.adept2.base.registry.AbstractRegistryAbstractRegistry.DefaultNameResolution, AbstractRegistry.InstanceInformation, AbstractRegistry.InstantiationMode
 - 
Nested classes/interfaces inherited from class de.aristaflow.adept2.base.service.AbstractADEPT2ServiceAbstractADEPT2Service.ActiveSessions
 
- 
 - 
Field SummaryFields Modifier and Type Field Description protected Class<T>initialServiceClsThe class of the initial service.protected StringinitialServiceTypeThe type name of the initial service.- 
Fields inherited from class de.aristaflow.adept2.core.registry.BootstrapRegistryinstanceName
 - 
Fields inherited from class de.aristaflow.adept2.base.registry.ServiceRegistryclusterName, GLOB_STUB_CACHING_REM_IT_ALIVE_TIME_EXTENSION, GLOB_STUB_CACHING_REM_IT_INIT_ALIVE_TIME, GLOB_STUB_PROXY_ANNOT_CACHE_SIZE, GLOB_STUB_PROXY_LAZY_METHOD_VALID_TIME, globalRegCache, hierInstName, protocolPriority, reexportedServices
 - 
Fields inherited from class de.aristaflow.adept2.base.registry.LocalServiceRegistryautoStartServices, failedServices, gsmAvailable, nodeName, release, serviceStarterPool, serviceStartLocker, shuttingDown, startedServices, startingLock, startingRequiredServices, startingService
 - 
Fields inherited from class de.aristaflow.adept2.base.registry.InstanceToInstanceRegistryusedInstances
 - 
Fields inherited from class de.aristaflow.adept2.base.registry.PluginRegistrydeclaredPluginTypes, defaultInstances, dynamicPlugins, pluginInstances, runtimePlugins, runtimePluginTypeCLs, singletonPlugins
 - 
Fields inherited from class de.aristaflow.adept2.base.registry.AbstractRegistrycomponentInterfaces, configurationManager, declaredInstances, INIT_INSTANTIATED_OBJECT_METHOD, nameResolution, singletonInstances
 - 
Fields inherited from class de.aristaflow.adept2.base.service.AbstractAuthenticatedServiceCFG_EARLY_SERVICEAUTH_ORGPOSID, CFG_EARLY_SERVICEAUTH_ORGPOSNAME, CFG_EARLY_SERVICEAUTH_PASSWORD, CFG_EARLY_SERVICEAUTH_USERNAME, CFG_SERVICEAUTH_ORGPOSID, CFG_SERVICEAUTH_ORGPOSNAME, CFG_SERVICEAUTH_PASSWORD, CFG_SERVICEAUTH_USERNAME
 - 
Fields inherited from class de.aristaflow.adept2.base.service.AbstractADEPT2ServiceCONF_CSV_LOGGING, configuration, logger, registry, runtimeRequiredServices, startupRequiredServices
 
- 
 - 
Constructor SummaryConstructors Constructor Description TwoPhaseBootstrap(Class<T> initialServiceCls, String initialServiceType, UrlConfigurationManager confMgr, Class<? extends BootstrapRegistry> bootstrapClass)Creates a new bootstrap registry having the designated configuration manager.
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description protected voidautoStartServices()Prepares the global security manager, authenticates this registry, provides the data sources for the runtime configurations to the configuration manager if appropriate, and starts all services to be automatically started at startup of this registry.protected voidbootstrap()Bootstraps this registry and therefore the platform.protected GlobalRegistrycontinueBootstrap()Continues the bootstrap.protected TgetInitialService()Gets the initial service that is provided in the first phase of bootstrapping.voidshutdownToInitialService()Shuts down all services until the initial service.- 
Methods inherited from class de.aristaflow.adept2.core.registry.BootstrapRegistrygetClientService, getRegistry, prepareGlobalSecurityManager, resolveInstanceName, shutdown, terminate
 - 
Methods inherited from class de.aristaflow.adept2.base.registry.ServiceRegistrybeforeLocalTermination, checkServiceURI, chooseAppropriateURI, createMBeanName, createRegistryWrapper, exportService, getCommunicationService, getGlobalRegistry, getInstanceNameFromServiceURI, getInvocationTarget, getLocallyExportedService, getLocalServiceObject, getService, getService, getServiceInformation, globalRegistryChanged, init, initExportServices, invalidateGlobalRegistry, prepareExport, prioritiseProtocols, readMetaConfiguration, start, unpublishService
 - 
Methods inherited from class de.aristaflow.adept2.base.registry.LocalServiceRegistrycheckServiceInterface, checkServiceUriSyntax, checkStartupRequiredService, createLocalServiceURI, determineNodeName, getAndCheckRequiredService, getConfiguredPlugin, getGlobalSequence, getInstantiationMode, getRegistry, getSecurityManager, getServiceForInstance, notifyDataSourceToConfMgr, registryActive, renewConfiguration, startLocalService, syncExecute, terminateService
 - 
Methods inherited from class de.aristaflow.adept2.base.registry.InstanceToInstanceRegistrygetUsedComponentInstanceNameForInstance, getUsedObjectForInstance
 - 
Methods inherited from class de.aristaflow.adept2.base.registry.PluginRegistrycreatePluginLoader, getConfiguredPlugin, getConfiguredPlugin, getConfiguredPlugins, getConfiguredPluginTypes, prepareRuntimePlugin, readMetaConfiguration
 - 
Methods inherited from class de.aristaflow.adept2.base.registry.AbstractRegistrycheckAndStoreProvidedObject, checkConfiguration, checkImplementingClass, checkSupertype, createInstanceForInterface, getAppropriateMethod, getArbitrarilyNamedObject, getComponentType, getFormattedSignature, getHierarchicalInstanceName, getInstanceInformation, getInterfaceForComponentType, getNames, getObjectForInstanceName, getObjectForInstanceName, getObjectForInstanceName, getSimpleInstanceName, initialiseInstantiatedObject
 - 
Methods inherited from class de.aristaflow.adept2.base.service.AbstractAuthenticatedService_sessionActive, authenticateService, awaitActiveSessions, createChildSession, createSession, getAgent, getSessionFactory, getStartupRequired, getTopLevelAgent, getUserCredentials, globalSecurityManagerAvailable, isEarlyService, sessionHasAllCapabilities, sessionHasAllTopLevelCapabilities, sessionHasCapability, sessionHasOneCapability, sessionHasOneTopLevelCapability
 - 
Methods inherited from class de.aristaflow.adept2.base.service.AbstractADEPT2Service_sessionFinished, activeOrInvalidServiceStateException, changeLogContext, changeLogContext, changeLogContext, consoleLog, csvLoggingEnabled, getClassSpecificJulLogger, getDependencyRegistry, getLocalUris, getLogger, getRelease, getRuntimeRequiredServices, getServiceInstanceName, getStartupRequiredServices, getURIs, isActive, isSessionActive, isShutdown, logMethodEntry, logMethodEntry, logMethodEntry, logMethodExit, logMethodExit, ping, preShutdown, privilegeSession, privilegeThread, revertLogContextChanges, sessionActive, sessionActive, sessionActive, sessionActive, sessionFinished, sessionFinished, signalShutdown, signalStart, unprivilegeThread
 - 
Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 - 
Methods inherited from interface de.aristaflow.adept2.base.service.ADEPT2ServicegetLocalUris, getRelease, getRuntimeRequiredServices, getServiceInstanceName, getStartupRequiredServices, getURIs, ping, preShutdown
 
- 
 
- 
- 
- 
Field Detail- 
initialServiceClsprotected final Class<T extends ADEPT2Service> initialServiceCls The class of the initial service.
 - 
initialServiceTypeprotected final String initialServiceType The type name of the initial service.
 
- 
 - 
Constructor Detail- 
TwoPhaseBootstrappublic TwoPhaseBootstrap(Class<T> initialServiceCls, String initialServiceType, UrlConfigurationManager confMgr, Class<? extends BootstrapRegistry> bootstrapClass) throws AbortServiceException Creates a new bootstrap registry having the designated configuration manager. Before creating the registry, the root configuration will be validated against the designated class. If an initial service is provided (via its class and component type name), this registry bootstraps in two phases. In the first phase only the initial service will be retrieved. This will start all services required by the initial service but not the registry itself.- Parameters:
- initialServiceCls- The class of the initial service. If this is- null, this registry will act like the normal- BootstrapRegistry.
- initialServiceType- The type name of the initial service. If this is- nullor the empty string, this registry will act like the normal- BootstrapRegistry.
- confMgr- The initial configuration manager that provides the root configuration and configurations for the loaded component instances.
- bootstrapClass- The class the root configuration is validated against the configuration description. Use this class unless you have a subclass that has its own configuration description.
- Throws:
- AbortServiceException- If the initialisation or starting of the registry fails, an- AbortServiceExceptionwill be thrown. If the registry configuration is invalid, a- ConfigurationExceptionwill be thrown.
 
 
- 
 - 
Method Detail- 
autoStartServicesprotected void autoStartServices() throws AbortServiceExceptionDescription copied from class:LocalServiceRegistryPrepares the global security manager, authenticates this registry, provides the data sources for the runtime configurations to the configuration manager if appropriate, and starts all services to be automatically started at startup of this registry.- Overrides:
- autoStartServicesin class- ServiceRegistry
- Throws:
- AbortServiceException- If there are problems preparing the security manager or starting one of the services to be automatically started, an- AbortServiceExceptionwill be thrown.
 
 - 
getInitialServiceprotected T getInitialService() Gets the initial service that is provided in the first phase of bootstrapping.- Returns:
- The initial service that is provided in the first phase of
         bootstrapping or nullif no initial service is specified.
 
 - 
bootstrapprotected void bootstrap() throws AbortServiceExceptionDescription copied from class:BootstrapRegistryBootstraps this registry and therefore the platform. The registry is initialised with either the configured URI or a local URI with the instance name. Afterwards the registry is started.- Overrides:
- bootstrapin class- BootstrapRegistry
- Throws:
- AbortServiceException- If the initialisation or starting of the registry fails, an- AbortServiceExceptionwill be thrown.
 
 - 
continueBootstrapprotected GlobalRegistry continueBootstrap() throws AbortServiceException Continues the bootstrap. This will autostart the services of the superclass.- Returns:
- The global registry which provides access to public services.
- Throws:
- AbortServiceException- If there are problems preparing the security manager or starting one of the services to be automatically started, an- AbortServiceExceptionwill be thrown.
- See Also:
- ServiceRegistry.autoStartServices()
 
 - 
shutdownToInitialServicepublic void shutdownToInitialService() Shuts down all services until the initial service. This can then be used before shutting down completely.
 
- 
 
-