The Cluster Membership object
Table of Contents
Introduction
    The membership component in the Apache Tribes Channel is responsible
    for dynamic discovery of other members(nodes) in the cluster.
    There are currently two different membership service, the org.apache.catalina.tribes.membership.McastService
    and the org.apache.catalina.tribes.membership.StaticMembershipService.
    The McastService builds a multicast based membership service
    that sends UDP packets to multicast IP addresses.
    The StaticMembershipService builds  a unicast based membership
    service that sends TCP packets to predefined member address.
  
Default Implementation
    The default implementation of the cluster group notification is built on top of multicast heartbeats
    sent using UDP packets to a multicast IP address.
    Cluster members are grouped together by using the same multicast address/port combination.
    Each member sends out a heartbeat with a given interval (frequency), and this
    heartbeat is used for dynamic discovery.
    In a similar fashion, if a heartbeat has not been received in a timeframe specified by dropTime
    ms. a member is considered suspect and the channel and any membership listener will be notified.
  
Attributes
Common Attributes
| Attribute | Description | 
|---|---|
| className | 
        The implementation of the membership component.
        Two implementations available,  | 
Multicast Attributes
| Attribute | Description | 
|---|---|
| className | 
      The value is  | 
| address | 
      The multicast address that the membership will broadcast its presence and listen
      for other heartbeats on. The default value is  | 
| port | 
      The multicast port, the default value is  | 
| frequency | 
      The frequency in milliseconds in which heartbeats are sent out. The default value is  | 
| dropTime | 
      The membership component will time out members and notify the Channel if a member fails to send a heartbeat within
      a give time. The default value is  | 
| bind | 
      Use this attribute if you wish to bind your multicast traffic to a specific network interface.
      By default, or when this attribute is unset, it tries to bind to  | 
| ttl | The time-to-live setting for the multicast heartbeats. This setting should be a value between 0 and 255. The default value is VM implementation specific. | 
| domain | 
      Apache Tribes has the ability to logically group members into domains, by using this domain attribute.
      The  | 
| soTimeout | 
      The sending and receiving of heartbeats is done on a single thread, hence to avoid blocking this thread forever,
      you can control the  | 
| recoveryEnabled | 
      In case of a network failure, Java multicast socket don't transparently fail over, instead the socket will continuously
      throw IOException upon each receive request. When recoveryEnabled is set to true, this will close the multicast socket
      and open a new socket with the same properties as defined above. | 
| recoveryCounter | 
      When  | 
| recoverySleepTime | 
      When  | 
| localLoopbackDisabled | 
      Membership uses multicast, it will call  | 
Static Membership Attributes
When using the static membership service you must ensure that the
    channelStartOptions attribute of the Cluster
    element is set to the default value of 15.
| Attribute | Description | 
|---|---|
| className | 
        The value is  | 
| connectTimeout | 
        Timeout for attempting a TCP connection to address of predefined static member.
        Default is  | 
| expirationTime | 
        If members have failed to update their alive time within the given time,
        this membership will notify the memberDisappeared event to cluster.
        Default is  | 
| rpcTimeout | 
        Timeout for messages that used for member notification to/from othee nodes.
        Default is  | 
| useThread | 
        If set to true, this membership service will start a local thread for
        sending a ping message. if set to  | 
| pingInterval | 
        If  | 
Nested Components
Static Membership Service allows nesting of a <LocalMember> and <Member> element.
StaticMember Attributes
LocalMember: 
    Static member that is the local member of the static cluster group.
    
Note: It is not necessary to explicitly configure the local member using the <LocalMember> element. All cluster members, including the local member, may be defined using the <Member> element and Tomcat work out which one is the local member.
| Attribute | Description | 
|---|---|
| className | Only one implementation available: org.apache.catalina.tribes.membership.StaticMember | 
| port | There is no need to set. The value of this attribute inherits from the cluster receiver setting. | 
| securePort | There is no need to set. The value of this attribute inherits from the cluster receiver setting. | 
| host | There is no need to set. The value of this attribute inherits from the cluster receiver setting. | 
| domain | The logical cluster domain for that this static member listens for cluster messages.
        Two different type of values are possible: 1. Regular string values like "staging-domain" or "tomcat-cluster" will be converted into bytes using ISO-8859-1 encoding. 2. byte array in string form, for example {216,123,12,3} | 
| uniqueId | A universally uniqueId for this static member.
        The values must be 16 bytes in the following form: 1. byte array in string form, for example {0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15} | 
Member: 
    Static member that add to the static cluster group.
    
| Attribute | Description | 
|---|---|
| className | Only one implementation available: org.apache.catalina.tribes.membership.StaticMember | 
| port | The port that this static member listens to for cluster messages | 
| securePort | The secure port this static member listens to for encrypted cluster messages
        default value is -1, this value means the member is not listening on a secure port | 
| host | The host (or network interface) that this static member listens for cluster messages.
        Three different type of values are possible: 1. IP address in the form of "216.123.1.23" 2. Hostnames like "tomcat01.mydomain.com" or "tomcat01" as long as they resolve correctly 3. byte array in string form, for example {216,123,12,3} | 
| domain | The logical cluster domain for that this static member listens for cluster messages.
        Two different type of values are possible: 1. Regular string values like "staging-domain" or "tomcat-cluster" will be converted into bytes using ISO-8859-1 encoding. 2. byte array in string form, for example {216,123,12,3} | 
| uniqueId | A universally uniqueId for this static member.
        The values must be 16 bytes in the following form: 1. byte array in string form, for example {0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15} | 
Setting
     <Membership className="org.apache.catalina.tribes.membership.StaticMembershipService">
       <Member className="org.apache.catalina.tribes.membership.StaticMember"
                  port="4004"
                  host="tomcat01.mydomain.com"
                  uniqueId="{0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15}"/>
       <Member className="org.apache.catalina.tribes.membership.StaticMember"
                  port="4004"
                  host="tomcat02.mydomain.com"
                  uniqueId="{1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,1}"/>
     </Membership>