public abstract class ContainerBase extends LifecycleMBeanBase implements Container
getInfo(), and may implement
 a replacement for invoke().
 
 All subclasses of this abstract base class will include support for a
 Pipeline object that defines the processing to be performed for each request
 received by the invoke() method of this class, utilizing the
 "Chain of Responsibility" design pattern.  A subclass should encapsulate its
 own processing functionality as a Valve, and configure this
 Valve into the pipeline by calling setBasic().
 
 This implementation fires property change events, per the JavaBeans design
 pattern, for changes in singleton properties.  In addition, it fires the
 following ContainerEvent events to listeners who register
 themselves with addContainerListener():
 
| Type | Data | Description | 
|---|---|---|
| addChild | Container | Child container added to this Container. | 
|  | Valve | Valve added to this Container. | 
| removeChild | Container | Child container removed from this Container. | 
|  | Valve | Valve removed from this Container. | 
| start | null | Container was started. | 
| stop | null | Container was stopped. | 
| Modifier and Type | Class and Description | 
|---|---|
| protected class  | ContainerBase.ContainerBackgroundProcessorPrivate runnable class to invoke the backgroundProcess method
 of this container and its children after a fixed delay. | 
| protected class  | ContainerBase.PrivilegedAddChildPerform addChild with the permissions of this class. | 
Lifecycle.SingleUse| Modifier and Type | Field and Description | 
|---|---|
| protected AccessLog | accessLogThe access log to use for requests normally handled by this container
 that have been handled earlier in the processing chain. | 
| protected int | backgroundProcessorDelayThe processor delay for this component. | 
| protected HashMap<String,Container> | childrenThe child Containers belonging to this Container, keyed by name. | 
| protected Cluster | clusterThe cluster with which this Container is associated. | 
| protected List<ContainerListener> | listenersThe container event listeners for this Container. | 
| protected Loader | loaderThe Loader implementation with which this Container is associated. | 
| protected Log | loggerThe Logger implementation with which this Container is associated. | 
| protected String | logNameAssociated logger name. | 
| protected Manager | managerThe Manager implementation with which this Container is associated. | 
| protected String | nameThe human-readable name of this Container. | 
| protected Container | parentThe parent Container to which this Container is a child. | 
| protected ClassLoader | parentClassLoaderThe parent class loader to be configured when we install a Loader. | 
| protected Pipeline | pipelineThe Pipeline object with which this Container is associated. | 
| protected DirContext | resourcesThe resources DirContext object with which this Container is associated. | 
| protected static StringManager | smThe string manager for this package. | 
| protected boolean | startChildrenWill children be started automatically when they are added. | 
| protected ThreadPoolExecutor | startStopExecutor | 
| protected PropertyChangeSupport | supportThe property change support for this component. | 
mserverADD_CHILD_EVENT, ADD_MAPPER_EVENT, ADD_VALVE_EVENT, REMOVE_CHILD_EVENT, REMOVE_MAPPER_EVENT, REMOVE_VALVE_EVENTAFTER_DESTROY_EVENT, AFTER_INIT_EVENT, AFTER_START_EVENT, AFTER_STOP_EVENT, BEFORE_DESTROY_EVENT, BEFORE_INIT_EVENT, BEFORE_START_EVENT, BEFORE_STOP_EVENT, CONFIGURE_START_EVENT, CONFIGURE_STOP_EVENT, PERIODIC_EVENT, START_EVENT, STOP_EVENT| Constructor and Description | 
|---|
| ContainerBase() | 
| Modifier and Type | Method and Description | 
|---|---|
| void | addChild(Container child)Add a new child Container to those associated with this Container,
 if supported. | 
| void | addContainerListener(ContainerListener listener)Add a container event listener to this component. | 
| void | addPropertyChangeListener(PropertyChangeListener listener)Add a property change listener to this component. | 
| void | addValve(Valve valve)Convenience method, intended for use by the digester to simplify the
 process of adding Valves to containers. | 
| void | backgroundProcess()Execute a periodic task, such as reloading, etc. | 
| protected void | destroyInternal()Sub-classes wishing to perform additional clean-up should override this
 method, ensuring that super.destroyInternal() is the last call in the
 overriding method. | 
| Container | findChild(String name)Return the child Container, associated with this Container, with
 the specified name (if any); otherwise, return  null | 
| Container[] | findChildren()Return the set of children Containers associated with this Container. | 
| ContainerListener[] | findContainerListeners()Return the set of container listeners associated with this Container. | 
| void | fireContainerEvent(String type,
                  Object data)Notify all container event listeners that a particular event has
 occurred for this Container. | 
| AccessLog | getAccessLog()Obtain the AccessLog to use to log a request/response that is destined
 for this container. | 
| int | getBackgroundProcessorDelay()Get the delay between the invocation of the backgroundProcess method on
 this container and its children. | 
| ObjectName[] | getChildren() | 
| Cluster | getCluster()Return the Cluster with which this Container is associated. | 
| protected Cluster | getClusterInternal() | 
| protected String | getDomainInternal()Method implemented by sub-classes to identify the domain in which MBeans
 should be registered. | 
| String | getInfo()Return descriptive information about this Container implementation and
 the corresponding version number, in the format
  <description>/<version>. | 
| Loader | getLoader()Return the Loader with which this Container is associated. | 
| protected Loader | getLoaderInternal() | 
| Log | getLogger()Return the Logger for this Container. | 
| Manager | getManager()Return the Manager with which this Container is associated. | 
| protected Manager | getManagerInternal() | 
| Object | getMappingObject()Deprecated.  | 
| String | getName()Return a name string (suitable for use by humans) that describes this
 Container. | 
| Container | getParent()Return the Container for which this Container is a child, if there is
 one. | 
| ClassLoader | getParentClassLoader()Return the parent class loader (if any) for this web application. | 
| Pipeline | getPipeline()Return the Pipeline object that manages the Valves associated with
 this Container. | 
| Realm | getRealm()Return the Realm with which this Container is associated. | 
| protected Realm | getRealmInternal() | 
| DirContext | getResources()Return the resources DirContext object with which this Container is
 associated. | 
| protected DirContext | getResourcesInternal() | 
| boolean | getStartChildren()Return if children of this container will be started automatically when
 they are added to this container. | 
| int | getStartStopThreads()Obtain the number of threads available for starting and stopping any
 children associated with this container. | 
| protected void | initInternal()Sub-classes wishing to perform additional initialization should override
 this method, ensuring that super.initInternal() is the first call in the
 overriding method. | 
| void | invoke(Request request,
      Response response)Process the specified Request, to produce the corresponding Response,
 by invoking the first Valve in our pipeline (if any), or the basic
 Valve otherwise. | 
| void | logAccess(Request request,
         Response response,
         long time,
         boolean useDefault)Check this container for an access log and if none is found, look to the
 parent. | 
| protected String | logName() | 
| void | removeChild(Container child)Remove an existing child Container from association with this parent
 Container. | 
| void | removeContainerListener(ContainerListener listener)Remove a container event listener from this component. | 
| void | removePropertyChangeListener(PropertyChangeListener listener)Remove a property change listener from this component. | 
| void | setBackgroundProcessorDelay(int delay)Set the delay between the invocation of the execute method on this
 container and its children. | 
| void | setCluster(Cluster cluster)Set the Cluster with which this Container is associated. | 
| void | setLoader(Loader loader)Set the Loader with which this Container is associated. | 
| void | setManager(Manager manager)Set the Manager with which this Container is associated. | 
| void | setName(String name)Set a name string (suitable for use by humans) that describes this
 Container. | 
| void | setParent(Container container)Set the parent Container to which this Container is being added as a
 child. | 
| void | setParentClassLoader(ClassLoader parent)Set the parent class loader (if any) for this web application. | 
| void | setRealm(Realm realm)Set the Realm with which this Container is associated. | 
| void | setResources(DirContext resources)Set the resources DirContext object with which this Container is
 associated. | 
| void | setStartChildren(boolean startChildren)Set if children of this container will be started automatically when
 they are added to this container. | 
| void | setStartStopThreads(int startStopThreads)Sets the number of threads available for starting and stopping any
 children associated with this container. | 
| protected void | startInternal()Start this component and implement the requirements
 of  LifecycleBase.startInternal(). | 
| protected void | stopInternal()Stop this component and implement the requirements
 of  LifecycleBase.stopInternal(). | 
| protected void | threadStart()Start the background thread that will periodically check for
 session timeouts. | 
| protected void | threadStop()Stop the background thread that is periodically checking for
 session timeouts. | 
getDomain, getObjectName, getObjectNameKeyProperties, postDeregister, postRegister, preDeregister, preRegister, register, setDomain, unregisteraddLifecycleListener, destroy, findLifecycleListeners, fireLifecycleEvent, getState, getStateName, getThrowOnFailure, init, removeLifecycleListener, setState, setState, setThrowOnFailure, start, stopclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitgetObjectNameaddLifecycleListener, destroy, findLifecycleListeners, getState, getStateName, init, removeLifecycleListener, start, stopprotected HashMap<String,Container> children
protected int backgroundProcessorDelay
protected List<ContainerListener> listeners
protected Loader loader
protected Log logger
protected String logName
protected Manager manager
protected Cluster cluster
protected String name
protected Container parent
protected ClassLoader parentClassLoader
protected Pipeline pipeline
protected DirContext resources
protected static final StringManager sm
protected boolean startChildren
protected PropertyChangeSupport support
protected volatile AccessLog accessLog
protected ThreadPoolExecutor startStopExecutor
public int getStartStopThreads()
ContainergetStartStopThreads in interface Containerpublic void setStartStopThreads(int startStopThreads)
ContainersetStartStopThreads in interface ContainerstartStopThreads - The new number of threads to be usedpublic int getBackgroundProcessorDelay()
getBackgroundProcessorDelay in interface Containerpublic void setBackgroundProcessorDelay(int delay)
setBackgroundProcessorDelay in interface Containerdelay - The delay in seconds between the invocation of
              backgroundProcess methodspublic String getInfo()
<description>/<version>.public Loader getLoader()
null.protected Loader getLoaderInternal()
public void setLoader(Loader loader)
public Log getLogger()
public Manager getManager()
null.getManager in interface Containernull.protected Manager getManagerInternal()
public void setManager(Manager manager)
setManager in interface Containermanager - The newly associated Manager@Deprecated public Object getMappingObject()
getMappingObject in interface Containerpublic Cluster getCluster()
null.getCluster in interface Containernull.protected Cluster getClusterInternal()
public void setCluster(Cluster cluster)
setCluster in interface Containercluster - The newly associated Clusterpublic String getName()
public void setName(String name)
setName in interface Containername - New name of this containerIllegalStateException - if this Container has already been
  added to the children of a parent Container (after which the name
  may not be changed)public boolean getStartChildren()
true if the children will be startedpublic void setStartChildren(boolean startChildren)
startChildren - New value of the startChildren flagpublic Container getParent()
null.public void setParent(Container container)
setParent in interface Containercontainer - Container to which this Container is being added
  as a childIllegalArgumentException - if this Container refuses to become
  attached to the specified Containerpublic ClassLoader getParentClassLoader()
getParentClassLoader in interface ContainerContainer.getParent().Container.getParentClassLoader(). If no
         parent has been set, return the system class loader.public void setParentClassLoader(ClassLoader parent)
setParentClassLoader in interface Containerparent - The new parent class loaderpublic Pipeline getPipeline()
getPipeline in interface Containerpublic Realm getRealm()
null.protected Realm getRealmInternal()
public void setRealm(Realm realm)
public DirContext getResources()
null.getResources in interface Containernull.protected DirContext getResourcesInternal()
public void setResources(DirContext resources)
setResources in interface Containerresources - The newly associated DirContextpublic void addChild(Container child)
setParent() method must be called, with this
 Container as an argument.  This method may thrown an
 IllegalArgumentException if this Container chooses not
 to be attached to the specified Container, in which case it is not addedaddChild in interface Containerchild - New child Container to be addedIllegalArgumentException - if this exception is thrown by
  the setParent() method of the child ContainerIllegalArgumentException - if the new child does not have
  a name unique from that of existing children of this ContainerIllegalStateException - if this Container does not support
  child Containerspublic void addContainerListener(ContainerListener listener)
addContainerListener in interface Containerlistener - The listener to addpublic void addPropertyChangeListener(PropertyChangeListener listener)
addPropertyChangeListener in interface Containerlistener - The listener to addpublic Container findChild(String name)
nullpublic Container[] findChildren()
findChildren in interface Containerpublic ContainerListener[] findContainerListeners()
findContainerListeners in interface Containerpublic void invoke(Request request, Response response) throws IOException, ServletException
invoke in interface Containerrequest - Request to be processedresponse - Response to be producedIllegalStateException - if neither a pipeline or a basic
  Valve have been configured for this ContainerIOException - if an input/output error occurred while
  processingServletException - if a ServletException was thrown
  while processing this requestpublic void removeChild(Container child)
removeChild in interface Containerchild - Existing child Container to be removedpublic void removeContainerListener(ContainerListener listener)
removeContainerListener in interface Containerlistener - The listener to removepublic void removePropertyChangeListener(PropertyChangeListener listener)
removePropertyChangeListener in interface Containerlistener - The listener to removeprotected void initInternal()
                     throws LifecycleException
LifecycleMBeanBaseinitInternal in class LifecycleMBeanBaseLifecycleException - If the initialisation failsprotected void startInternal()
                      throws LifecycleException
LifecycleBase.startInternal().startInternal in class LifecycleBaseLifecycleException - if this component detects a fatal error
  that prevents this component from being usedprotected void stopInternal()
                     throws LifecycleException
LifecycleBase.stopInternal().stopInternal in class LifecycleBaseLifecycleException - if this component detects a fatal error
  that prevents this component from being usedprotected void destroyInternal()
                        throws LifecycleException
LifecycleMBeanBasedestroyInternal in class LifecycleMBeanBaseLifecycleException - If the destruction failspublic void logAccess(Request request, Response response, long time, boolean useDefault)
logAccess in interface Containerrequest - Request (associated with the response) to logresponse - Response (associated with the request) to logtime - Time taken to process the request/response in
                      milliseconds (use 0 if not known)useDefault - Flag that indicates that the request/response should
                      be logged in the engine's default access logpublic AccessLog getAccessLog()
ContainergetAccessLog in interface Containerpublic void addValve(Valve valve)
Pipeline.addValve(Valve) for full details. Components other than
 the digester should use getPipeline().addValve(Valve) in case a
 future implementation provides an alternative method for the digester to
 use.valve - Valve to be addedIllegalArgumentException - if this Container refused to
  accept the specified ValveIllegalArgumentException - if the specified Valve refuses to be
  associated with this ContainerIllegalStateException - if the specified Valve is already
  associated with a different Containerpublic void backgroundProcess()
backgroundProcess in interface Containerpublic void fireContainerEvent(String type, Object data)
fireContainerEvent in interface Containertype - Event typedata - Event dataprotected String logName()
protected String getDomainInternal()
LifecycleMBeanBasegetDomainInternal in class LifecycleMBeanBasepublic ObjectName[] getChildren()
protected void threadStart()
protected void threadStop()
Copyright © 2000-2020 Apache Software Foundation. All Rights Reserved.