|
||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||
java.lang.Objectorg.jgroups.stack.Protocol
org.jgroups.protocols.TP
org.jgroups.protocols.UDP
public class UDP
IP multicast transport based on UDP. Messages to the group (msg.dest == null) will be multicast (to all group members), whereas point-to-point messages (msg.dest != null) will be unicast to a single member. Uses a multicast and a unicast socket.
The following properties are read by the UDP protocol:
| Nested Class Summary | |
|---|---|
class |
UDP.UcastReceiver
|
| Nested classes/interfaces inherited from class org.jgroups.protocols.TP |
|---|
TP.ProbeHandler, TP.ProtocolAdapter |
| Field Summary |
|---|
| Fields inherited from class org.jgroups.protocols.TP |
|---|
bind_addr, channel_name, discard_incompatible_packets, global_thread_factory, local_addr, members, persistent_ports, persistent_ports_file, pm, pm_expiry_time, thread_naming_pattern, timer, timer_thread_factory, view |
| Fields inherited from class org.jgroups.stack.Protocol |
|---|
down_prot, log, props, stack, stats, up_prot |
| Constructor Summary | |
|---|---|
UDP()
Creates the UDP protocol, and initializes the state variables, does however not start any sockets or threads. |
|
| Method Summary | |
|---|---|
protected java.net.DatagramSocket |
createDatagramSocketWithBindPort()
Creates a DatagramSocket when bind_port > 0. |
protected java.net.DatagramSocket |
createEphemeralDatagramSocket()
Creates a DatagramSocket with a random port. |
protected Address |
createLocalAddress()
|
java.lang.String |
getInfo()
|
java.lang.String |
getName()
|
protected void |
handleConfigEvent(java.util.Map<java.lang.String,java.lang.Object> map)
|
protected void |
handleConnect()
|
protected void |
handleDisconnect()
|
void |
postUnmarshalling(Message msg,
Address dest,
Address src,
boolean multicast)
|
void |
postUnmarshallingList(Message msg,
Address dest,
boolean multicast)
|
void |
run()
|
void |
sendToAllMembers(byte[] data,
int offset,
int length)
Send to all members in the group. |
void |
sendToSingleMember(Address dest,
byte[] data,
int offset,
int length)
Send to all members in the group. |
void |
setMcastPort(int p)
|
boolean |
setProperties(java.util.Properties props)
Setup the Protocol instance acording to the configuration string. |
protected void |
setThreadNames()
|
void |
start()
Creates the unicast and multicast sockets and starts the unicast and multicast receiver threads |
void |
stop()
This method is called on a Channel.disconnect(). |
protected void |
unsetThreadNames()
|
| Methods inherited from class org.jgroups.stack.Protocol |
|---|
downThreadEnabled, enableStats, getDownProtocol, getProperties, getProtocolStack, getTransport, getUpProtocol, printStats, providedDownServices, providedUpServices, requiredDownServices, requiredUpServices, setDownProtocol, setPropertiesInternal, setProtocolStack, setUpProtocol, statsEnabled, upThreadEnabled |
| Methods inherited from class java.lang.Object |
|---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait |
| Constructor Detail |
|---|
public UDP()
| Method Detail |
|---|
public boolean setProperties(java.util.Properties props)
setProperties in class TPpublic void setMcastPort(int p)
public void run()
run in interface java.lang.Runnablepublic java.lang.String getInfo()
getInfo in class TP
public void sendToAllMembers(byte[] data,
int offset,
int length)
throws java.lang.Exception
TP
sendToAllMembers in class TPdata - The data to be sent. This is not a copy, so don't modify it
java.lang.Exception
public void sendToSingleMember(Address dest,
byte[] data,
int offset,
int length)
throws java.lang.Exception
TP
sendToSingleMember in class TPdest - Must be a non-null unicast addressdata - The data to be sent. This is not a copy, so don't modify it
java.lang.Exception
public void postUnmarshalling(Message msg,
Address dest,
Address src,
boolean multicast)
postUnmarshalling in class TP
public void postUnmarshallingList(Message msg,
Address dest,
boolean multicast)
postUnmarshallingList in class TPpublic java.lang.String getName()
getName in class Protocol
public void start()
throws java.lang.Exception
start in class TPjava.lang.Exception - Thrown if protocol cannot be started successfully. This will cause the ProtocolStack
to fail, so Channel.connect(String) will throw an exceptionpublic void stop()
ProtocolChannel.disconnect(). Stops work (e.g. by closing multicast socket).
Will be called from top to bottom. This means that at the time of the method invocation the
neighbor protocol below is still working. This method will replace the
STOP, STOP_OK, CLEANUP and CLEANUP_OK events. The ProtocolStack guarantees that
when this method is called all messages in the down queue will have been flushed
stop in class TP
protected void handleConnect()
throws java.lang.Exception
handleConnect in class TPjava.lang.Exceptionprotected void handleDisconnect()
handleDisconnect in class TPprotected Address createLocalAddress()
protected java.net.DatagramSocket createEphemeralDatagramSocket()
throws java.net.SocketException
java.net.SocketException
protected java.net.DatagramSocket createDatagramSocketWithBindPort()
throws java.lang.Exception
java.lang.Exceptionprotected void setThreadNames()
setThreadNames in class TPprotected void unsetThreadNames()
unsetThreadNames in class TPprotected void handleConfigEvent(java.util.Map<java.lang.String,java.lang.Object> map)
handleConfigEvent in class TP
|
||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||