[code.view]

[top] / java / tomcat / webapps / docs / config / cluster-manager.xml

     <?xml version="1.0"?>
     <!--
       Licensed to the Apache Software Foundation (ASF) under one or more
       contributor license agreements.  See the NOTICE file distributed with
       this work for additional information regarding copyright ownership.
       The ASF licenses this file to You under the Apache License, Version 2.0
       (the "License"); you may not use this file except in compliance with
       the License.  You may obtain a copy of the License at
     
           http://www.apache.org/licenses/LICENSE-2.0
     
       Unless required by applicable law or agreed to in writing, software
       distributed under the License is distributed on an "AS IS" BASIS,
       WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
       See the License for the specific language governing permissions and
       limitations under the License.
     -->
     <!DOCTYPE document [
       <!ENTITY project SYSTEM "project.xml">
     ]>
     <document url="cluster-manager.html">
     
       &project;
     
       <properties>
         <author email="fhanik@apache.org">Filip Hanik</author>
         <title>The ClusterManager object</title>
       </properties>
     
     <body>
     
     <section name="Table of Contents">
     <toc/>
     </section>
     
     <section name="Introduction">
       <p>A cluster manager is an extension to Tomcat's session manager interface, 
       <code>org.apache.catalina.Manager</code>.
       A cluster manager must implement the
       <code>org.apache.catalina.ha.ClusterManager</code> and is solely  responsible
       for how the session is replicated.<br/>
       There are currently two different managers, the
       <code>org.apache.catalina.ha.session.DeltaManager</code> replicates deltas of
       session data to all members in the cluster. This implementation is proven and
       works very well, but has a limitation as it requires the cluster members to be
       homogeneous, all nodes must deploy the same applications and be exact
       replicas. The <code>org.apache.catalina.ha.session.BackupManager</code> also
       replicates deltas but only to one backup node. The location of the backup node
       is known to all nodes in the cluster. It also supports heterogeneous
       deployments, so the manager knows at what locations the web application is
       deployed.</p>
     </section>
     
     <section name="The <Manager>">
       <p>The <code><Manager></code> element defined inside the
       <code><Cluster></code> element is the template defined for all web
       applications that are marked <code><distributable/></code> in their
       <code>web.xml</code> file. However, you can still override the manager
       implementation on a per web application basis, by putting the
       <code><Manager></code> inside the <code><Context></code> element
       either in the <code><a href="context.html">context.xml</a></code> file or the
       <code><a href="index.html">server.xml</a></code> file.</p> 
     </section>
     
     <section name="Attributes">
       <subsection name="Common Attributes">
         <attributes>
           <attribute name="className" required="true">
           </attribute>
           <attribute name="name" required="false">
             <b>The name of this cluster manager, the name is used to identify a
             session manager on a node. The name might get modified by the
             <code>Cluster</code> element to make it unique in the container.</b>
           </attribute>
           <attribute name="defaultMode" required="false">
             <b>Deprecated since 6.0.0</b>
           </attribute>
           <attribute name="notifyListenersOnReplication" required="false">
             Set to <code>true</code> if you wish to have session listeners notified
             when session attributes are being replicated or removed across Tomcat
             nodes in the cluster.
           </attribute>
           <attribute name="expireSessionsOnShutdown" required="false">
             When a web application is being shutdown, Tomcat issues an expire call
             to each session to notify all the listeners. If you wish for all
             sessions to expire on all nodes when a shutdown occurs on one node, set
             this value to <code>true</code>. Default value is <code>false</code>.
           </attribute>
         </attributes>
       </subsection> 
       <subsection name="org.apache.catalina.ha.session.DeltaManager Attributes">
         <attributes>
           <attribute name="domainReplication" required="false">
             <b>Deprecated since 6.0.0</b><br/>
             If you wish sessions to be replicated only to members that have the 
             same logical domain set, use 
             <code><a href="cluster-interceptor.html">DomainFilterInterceptor </a></code>.
           </attribute>
           <attribute name="expireSessionsOnShutdown" required="false">
             When a web application is being shutdown, Tomcat issues an expire call
             to each session to notify all the listeners. If you wish for all
             sessions to expire on all nodes when a shutdown occurs on one node, set
             this value to <code>true</code>.
             Default value is <code>false</code>.
           </attribute>
           <attribute name="maxActiveSessions" required="false">
             The maximum number of active sessions that will be created by this
             Manager, or -1 (the default) for no limit. For this manager, all
             sessions are counted as active sessions irrespective if whether or not
             the current node is the primary node for the session.
           </attribute>
           <attribute name="notifySessionListenersOnReplication" required="false">
             Set to <code>true</code> if you wish to have session listeners notified
             when sessions are created and expired across Tomcat nodes in the
             cluster.
           </attribute>
           <attribute name="notifyContainerListenersOnReplication" required="false">
             Set to <code>true</code> if you wish to have container listeners notified
             across Tomcat nodes in the cluster.
           </attribute>
           <attribute name="stateTransferTimeout" required="false">
             The time in seconds to wait for a session state transfer to complete
             from another node when a node is starting up.
             Default value is <code>60</code> seconds.
           </attribute>
           <attribute name="sessionAttributeFilter" required="false">
             A regular expression used to filter, which session attributes will
             be replicated. An attribute will only be replicated, if its name
             matches this pattern. If the pattern is not set (default), all
             attributes are eligible for replication. As an example, the value
             <code>^(userName|sessionHistory)$</code> will only replicate the two
             session attributes named <code>userName</code> and
             <code>sessionHistory</code>.
           </attribute>
         </attributes>
       </subsection>
       <subsection name="org.apache.catalina.ha.session.BackupManager Attributes">
         <attributes>
           <attribute name="mapSendOptions" required="false">
             The backup manager uses a replicated map, this map is sending and
             receiving messages. You can setup the flag for how this map is sending
             messages, the default value is <code>6</code>(synchronous).<br/>
             Note that if you use asynchronous messaging it is possible for update
             messages for a session to be processed by the receiving node in a
             different order to the order in which they were sent.
           </attribute>
           <attribute name="maxActiveSessions" required="false">
             The maximum number of active sessions that will be created by this
             Manager, or -1 (the default) for no limit. For this manager, only
             sessions where the current node is the primary node for the session are
             considered active sessions.
           </attribute>
           <attribute name="rpcTimeout" required="false">
             Timeout for RPC message used for broadcast and transfer state from 
             another map.
             Default value is <code>15000</code> milliseconds.
           </attribute>
         </attributes>
       </subsection>
     </section>
     </body>
     </document>
     

[top] / java / tomcat / webapps / docs / config / cluster-manager.xml

contact | logmethods.com