public class ReplicatedTree extends ReceiverAdapter
限定符和类型 | 类和说明 |
---|---|
static class |
ReplicatedTree.Node |
static interface |
ReplicatedTree.ReplicatedTreeListener |
构造器和说明 |
---|
ReplicatedTree() |
ReplicatedTree(JChannel channel)
Expects an already connected channel.
|
ReplicatedTree(java.lang.String groupname,
java.lang.String props,
long state_fetch_timeout)
Creates a channel with the given properties.
|
ReplicatedTree(java.lang.String groupname,
java.lang.String props,
long state_fetch_timeout,
boolean jmx) |
限定符和类型 | 方法和说明 |
---|---|
void |
_put(java.lang.String fqn,
java.util.HashMap data) |
void |
_put(java.lang.String fqn,
java.lang.String key,
java.lang.Object value) |
void |
_remove(java.lang.String fqn) |
void |
_remove(java.lang.String fqn,
java.lang.String key) |
void |
_removeData(java.lang.String fqn) |
void |
addReplicatedTreeListener(ReplicatedTree.ReplicatedTreeListener listener) |
boolean |
exists(java.lang.String fqn)
Checks whether a given node exists in the tree
|
void |
fetchState(long timeout)
Fetch the group state from the current coordinator.
|
java.lang.Object |
get(java.lang.String fqn,
java.lang.String key)
Finds a node given its name and returns the value associated with a given key in its
data
map. |
Channel |
getChannel()
Returns the Channel the DistributedTree is connected to
|
java.util.Set |
getChildrenNames(java.lang.String fqn)
Returns all children of a given node
|
int |
getGroupMembersNumber()
Returns the number of current members joined to the group
|
java.lang.String |
getGroupName()
Returns the name of the group that the DistributedTree is connected to
|
java.util.Set |
getKeys(java.lang.String fqn)
Gets the keys of the
data map. |
Address |
getLocalAddress() |
java.util.List<Address> |
getMembers() |
void |
getState(java.io.OutputStream ostream)
Allows an application to write a state through a provided OutputStream.
|
static void |
main(java.lang.String[] args) |
java.lang.String |
print(java.lang.String fqn)
Prints a representation of the node defined by
fqn . |
void |
put(java.lang.String fqn,
java.util.HashMap data)
Adds a new node to the tree and sets its data.
|
void |
put(java.lang.String fqn,
java.lang.String key,
java.lang.Object value)
Adds a key and value to a given node.
|
void |
receive(Message msg)
Callback.
|
void |
remove(java.lang.String fqn)
Removes the node from the tree.
|
void |
remove(java.lang.String fqn,
java.lang.String key)
Removes
key from the node's hashmap |
void |
removeReplicatedTreeListener(ReplicatedTree.ReplicatedTreeListener listener) |
void |
setRemoteCalls(boolean flag) |
void |
setRootNode(ReplicatedTree.Node n) |
void |
setState(java.io.InputStream istream)
Allows an application to read a state through a provided InputStream.
|
void |
start() |
void |
stop() |
java.lang.String |
toString() |
void |
viewAccepted(View new_view)
Called when a change in membership has occurred.
|
block, suspect, unblock
public static final java.lang.String SEPARATOR
protected final Log log
public ReplicatedTree(java.lang.String groupname, java.lang.String props, long state_fetch_timeout) throws java.lang.Exception
java.lang.Exception
public ReplicatedTree(java.lang.String groupname, java.lang.String props, long state_fetch_timeout, boolean jmx) throws java.lang.Exception
java.lang.Exception
public ReplicatedTree()
public ReplicatedTree(JChannel channel) throws java.lang.Exception
java.lang.Exception
public void setRemoteCalls(boolean flag)
public void setRootNode(ReplicatedTree.Node n)
public Address getLocalAddress()
public java.util.List<Address> getMembers()
public void fetchState(long timeout) throws java.lang.Exception
java.lang.Exception
public void addReplicatedTreeListener(ReplicatedTree.ReplicatedTreeListener listener)
public void removeReplicatedTreeListener(ReplicatedTree.ReplicatedTreeListener listener)
public final void start() throws java.lang.Exception
java.lang.Exception
public void stop()
public void put(java.lang.String fqn, java.util.HashMap data)
fqn
- The fully qualified name of the new nodedata
- The new data. May be null if no data should be set in the node.public void put(java.lang.String fqn, java.lang.String key, java.lang.Object value)
fqn
- The fully qualified name of the nodekey
- The keyvalue
- The valuepublic void remove(java.lang.String fqn)
fqn
- The fully qualified name of the node.public void remove(java.lang.String fqn, java.lang.String key)
key
from the node's hashmapfqn
- The fullly qualified name of the nodekey
- The key to be removedpublic boolean exists(java.lang.String fqn)
fqn
- The fully qualified name of the nodepublic java.util.Set getKeys(java.lang.String fqn)
data
map. Returns all keys as Strings. Returns null if node
does not exist.fqn
- The fully qualified name of the nodepublic java.lang.Object get(java.lang.String fqn, java.lang.String key)
data
map. Returns null if the node was not found in the tree or the key was not found in the hashmap.fqn
- The fully qualified name of the node.key
- The key.public java.lang.String print(java.lang.String fqn)
fqn
. Output includes name, fqn and
data.public java.util.Set getChildrenNames(java.lang.String fqn)
fqn
- The fully qualified name of the nodepublic java.lang.String toString()
toString
在类中 java.lang.Object
public java.lang.String getGroupName()
public Channel getChannel()
public int getGroupMembersNumber()
public void _put(java.lang.String fqn, java.util.HashMap data)
public void _put(java.lang.String fqn, java.lang.String key, java.lang.Object value)
public void _remove(java.lang.String fqn)
public void _remove(java.lang.String fqn, java.lang.String key)
public void _removeData(java.lang.String fqn)
public void receive(Message msg)
receive
在接口中 MessageListener
receive
在类中 ReceiverAdapter
public void getState(java.io.OutputStream ostream) throws java.lang.Exception
ReceiverAdapter
getState
在接口中 MessageListener
getState
在类中 ReceiverAdapter
ostream
- the OutputStreamjava.lang.Exception
- if the streaming fails, any exceptions should be thrown so that the state requester
can re-throw them and let the caller know what happenedOutputStream.close()
public void setState(java.io.InputStream istream) throws java.lang.Exception
ReceiverAdapter
setState
在接口中 MessageListener
setState
在类中 ReceiverAdapter
istream
- the InputStreamjava.lang.Exception
- if the streaming fails, any exceptions should be thrown so that the state requester
can catch them and thus know what happenedInputStream.close()
public void viewAccepted(View new_view)
ReceiverAdapter
Channel.connect(String)
returns.viewAccepted
在接口中 MembershipListener
viewAccepted
在类中 ReceiverAdapter
public static void main(java.lang.String[] args)