Enum EphemeralType
- java.lang.Object
-
- java.lang.Enum<EphemeralType>
-
- org.apache.zookeeper.server.EphemeralType
-
- All Implemented Interfaces:
Serializable,Comparable<EphemeralType>
public enum EphemeralType extends Enum<EphemeralType>
Abstraction that interprets the
ephemeralOwnerfield of a ZNode. Originally, the ephemeralOwner noted that a ZNode is ephemeral and which session created the node. Through an optional system property (zookeeper.extendedTypesEnabled) "extended" features such as TTL Nodes can be enabled. Special bits of the ephemeralOwner are used to denote which feature is enabled and the remaining bits of the ephemeralOwner are feature specific.When the system property
zookeeper.extendedTypesEnabledis true, extended types are enabled. An extended ephemeralOwner is defined as an ephemeralOwner whose high 8 bits are set (0xff00000000000000L). The two bytes that follow the high 8 bits are used to denote which extended feature the ephemeralOwner represents. The remaining 5 bytes are used by the feature for whatever purpose is neededCurrently, the only extended feature is TTL Nodes. It is denoted by the extended feature value of 0. i.e. for TTL Nodes, the ephemeralOwner has the high byte set to 0xff and the next 2 bytes are 0 followed by 5 bytes that represent the TTL value in milliseconds. So, an ephemeralOwner with a TTL value of 1 millisecond is:
0xff00000000000001.To add new extended features: a) Add a new name to the enum, b) define a constant EXTENDED_BIT_xxxx that's next in line (after TTLs, that would be
0x0001), c) add a mapping to the extendedFeatureMap via the static initializerNOTE: "Container" nodes technically are extended types but as it was implemented before this feature they are denoted specially. An ephemeral owner with only the high bit set (
0x8000000000000000L) is by definition a container node (irrespective of whether or not extended types are enabled).
-
-
Field Summary
Fields Modifier and Type Field Description static longCONTAINER_EPHEMERAL_OWNERstatic longMAX_EXTENDED_SERVER_ID
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description static booleanextendedEphemeralTypesEnabled()Return true if extended ephemeral types are enabledstatic EphemeralTypeget(long ephemeralOwner)Convert a ZNode ephemeral owner to an ephemeral type.longgetValue(long ephemeralOwner)For types that support it, return the extended value from an extended ephemeral ownerlongmaxValue()For types that support it, the maximum extended valuelongtoEphemeralOwner(long value)For types that support it, convert a value to an extended ephemeral ownerstatic voidvalidateServerId(long serverId)Make sure the given server ID is compatible with the current extended ephemeral settingstatic voidvalidateTTL(CreateMode mode, long ttl)Utility to validate a create mode and a ttlstatic EphemeralTypevalueOf(String name)Returns the enum constant of this type with the specified name.static EphemeralType[]values()Returns an array containing the constants of this enum type, in the order they are declared.
-
-
-
Enum Constant Detail
-
VOID
public static final EphemeralType VOID
Not ephemeral
-
NORMAL
public static final EphemeralType NORMAL
Standard, pre-3.5.x EPHEMERAL
-
CONTAINER
public static final EphemeralType CONTAINER
Container node
-
TTL
public static final EphemeralType TTL
TTL node
-
-
Field Detail
-
CONTAINER_EPHEMERAL_OWNER
public static final long CONTAINER_EPHEMERAL_OWNER
- See Also:
- Constant Field Values
-
MAX_EXTENDED_SERVER_ID
public static final long MAX_EXTENDED_SERVER_ID
- See Also:
- Constant Field Values
-
-
Method Detail
-
values
public static EphemeralType[] values()
Returns an array containing the constants of this enum type, in the order they are declared. This method may be used to iterate over the constants as follows:for (EphemeralType c : EphemeralType.values()) System.out.println(c);
- Returns:
- an array containing the constants of this enum type, in the order they are declared
-
valueOf
public static EphemeralType valueOf(String name)
Returns the enum constant of this type with the specified name. The string must match exactly an identifier used to declare an enum constant in this type. (Extraneous whitespace characters are not permitted.)- Parameters:
name- the name of the enum constant to be returned.- Returns:
- the enum constant with the specified name
- Throws:
IllegalArgumentException- if this enum type has no constant with the specified nameNullPointerException- if the argument is null
-
maxValue
public long maxValue()
For types that support it, the maximum extended value- Returns:
- 0 or max
-
toEphemeralOwner
public long toEphemeralOwner(long value)
For types that support it, convert a value to an extended ephemeral owner- Returns:
- 0 or extended ephemeral owner
-
getValue
public long getValue(long ephemeralOwner)
For types that support it, return the extended value from an extended ephemeral owner- Returns:
- 0 or extended value
-
extendedEphemeralTypesEnabled
public static boolean extendedEphemeralTypesEnabled()
Return true if extended ephemeral types are enabled- Returns:
- true/false
-
get
public static EphemeralType get(long ephemeralOwner)
Convert a ZNode ephemeral owner to an ephemeral type. If extended types are not enabled, VOID or NORMAL is always returned- Parameters:
ephemeralOwner- the ZNode's ephemeral owner- Returns:
- type
-
validateServerId
public static void validateServerId(long serverId)
Make sure the given server ID is compatible with the current extended ephemeral setting- Parameters:
serverId- Server ID- Throws:
RuntimeException- extendedTypesEnabled is true but Server ID is too large
-
validateTTL
public static void validateTTL(CreateMode mode, long ttl)
Utility to validate a create mode and a ttl- Parameters:
mode- create modettl- ttl- Throws:
IllegalArgumentException- if the ttl is not valid for the mode
-
-