Rice Pastry API

rice.pastry.socket
Class PingManager

java.lang.Object
  extended byrice.selector.SelectionKeyHandler
      extended byrice.pastry.socket.PingManager

public class PingManager
extends SelectionKeyHandler

Version:
$Id: PingManager.java 3274 2006-05-15 16:17:47Z jeffh $
Author:
jeffh To change the template for this generated type comment go to Window>Preferences>Java>Code Generation>Code and Comments

Nested Class Summary
 class PingManager.Envelope
          Internal class which holds a pending datagram
 
Field Summary
 int DATAGRAM_RECEIVE_BUFFER_SIZE
          DESCRIBE THE FIELD
 int DATAGRAM_SEND_BUFFER_SIZE
          DESCRIBE THE FIELD
static int HEADER_SIZE
          DESCRIBE THE FIELD
protected  java.util.WeakHashMap lastPingTime
          DESCRIBE THE FIELD
protected  java.util.ArrayList pendingMsgs
          DESCRIBE THE FIELD
static int PING_THROTTLE
          DESCRIBE THE FIELD
protected  java.util.WeakHashMap pingListeners
          DESCRIBE THE FIELD
 
Constructor Summary
PingManager(SocketPastryNode spn, SocketSourceRouteManager manager, EpochInetSocketAddress bindAddress, EpochInetSocketAddress proxyAddress)
           
 
Method Summary
protected  void addPingResponseListener(SourceRoute path, PingResponseListener prl)
          Adds a feature to the PingResponseListener attribute of the PingManager object
 SourceRoute decodeHeader(byte[] header)
          Method which adds a header for the provided path to the given data.
 void enqueue(SourceRoute path, PRawMessage msg)
          DESCRIBE THE METHOD
 void enqueue(SourceRoute path, SocketBuffer msg)
          DESCRIBE THE METHOD
 void modifyKey(java.nio.channels.SelectionKey key)
          DESCRIBE THE METHOD
protected  void notifyPingResponseListeners(SourceRoute path, int proximity, long lastTimePinged)
          caller must synchronized(pingResponseTimes)
protected  void ping(SourceRoute path, PingResponseListener prl)
          Method which actually sends a ping to over the specified path, and returns the result to the specified listener.
 void read(java.nio.channels.SelectionKey key)
          DESCRIBE THE METHOD
protected  void readHeader(java.net.InetSocketAddress address)
          Method which processes an incoming message and hands it off to the appropriate handler.
 void receiveMessage(SourceRoute sr, DatagramMessage dm, int size, java.net.InetSocketAddress from)
          DESCRIBE THE METHOD
protected  void removePingResponseListener(SourceRoute path, PingResponseListener prl)
          Adds a feature to the PingResponseListener attribute of the PingManager object
protected  void resign()
          Makes this node resign from the network.
 void stall()
          Internal testing method which simulates a stall.
 void write(java.nio.channels.SelectionKey key)
          DESCRIBE THE METHOD
 
Methods inherited from class rice.selector.SelectionKeyHandler
accept, connect
 
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 

Field Detail

DATAGRAM_RECEIVE_BUFFER_SIZE

public final int DATAGRAM_RECEIVE_BUFFER_SIZE
DESCRIBE THE FIELD


DATAGRAM_SEND_BUFFER_SIZE

public final int DATAGRAM_SEND_BUFFER_SIZE
DESCRIBE THE FIELD


pingListeners

protected java.util.WeakHashMap pingListeners
DESCRIBE THE FIELD


lastPingTime

protected java.util.WeakHashMap lastPingTime
DESCRIBE THE FIELD


pendingMsgs

protected java.util.ArrayList pendingMsgs
DESCRIBE THE FIELD


PING_THROTTLE

public static final int PING_THROTTLE
DESCRIBE THE FIELD

See Also:
Constant Field Values

HEADER_SIZE

public static int HEADER_SIZE
DESCRIBE THE FIELD

Constructor Detail

PingManager

public PingManager(SocketPastryNode spn,
                   SocketSourceRouteManager manager,
                   EpochInetSocketAddress bindAddress,
                   EpochInetSocketAddress proxyAddress)
            throws java.io.IOException
Parameters:
manager - DESCRIBE THE PARAMETER
spn - DESCRIBE THE PARAMETER
bindAddress - DESCRIBE THE PARAMETER
proxyAddress - DESCRIBE THE PARAMETER
Throws:
java.io.IOException - DESCRIBE THE EXCEPTION
Method Detail

ping

protected void ping(SourceRoute path,
                    PingResponseListener prl)
Method which actually sends a ping to over the specified path, and returns the result to the specified listener. Note that if no ping response is ever received, the listener is never called.

Parameters:
path - The path to send the ping over
prl - The listener which should hear about the response

resign

protected void resign()
               throws java.io.IOException
Makes this node resign from the network. Is designed to be used for debugging and testing.

Throws:
java.io.IOException - DESCRIBE THE EXCEPTION

stall

public void stall()
Internal testing method which simulates a stall. DO NOT USE!!!!!


removePingResponseListener

protected void removePingResponseListener(SourceRoute path,
                                          PingResponseListener prl)
Adds a feature to the PingResponseListener attribute of the PingManager object

Parameters:
prl - The feature to be added to the PingResponseListener attribute
path - DESCRIBE THE PARAMETER

addPingResponseListener

protected void addPingResponseListener(SourceRoute path,
                                       PingResponseListener prl)
Adds a feature to the PingResponseListener attribute of the PingManager object

Parameters:
prl - The feature to be added to the PingResponseListener attribute
path - The feature to be added to the PingResponseListener attribute

notifyPingResponseListeners

protected void notifyPingResponseListeners(SourceRoute path,
                                           int proximity,
                                           long lastTimePinged)
caller must synchronized(pingResponseTimes)

Parameters:
proximity -
lastTimePinged -
path - DESCRIBE THE PARAMETER

enqueue

public void enqueue(SourceRoute path,
                    PRawMessage msg)
DESCRIBE THE METHOD

Parameters:
path - DESCRIBE THE PARAMETER
msg - DESCRIBE THE PARAMETER

enqueue

public void enqueue(SourceRoute path,
                    SocketBuffer msg)
DESCRIBE THE METHOD

Parameters:
msg - DESCRIBE THE PARAMETER
path - DESCRIBE THE PARAMETER

receiveMessage

public void receiveMessage(SourceRoute sr,
                           DatagramMessage dm,
                           int size,
                           java.net.InetSocketAddress from)
                    throws java.io.IOException
DESCRIBE THE METHOD

Parameters:
sr - DESCRIBE THE PARAMETER
dm - DESCRIBE THE PARAMETER
size - DESCRIBE THE PARAMETER
from - DESCRIBE THE PARAMETER
Throws:
java.io.IOException - DESCRIBE THE EXCEPTION

read

public void read(java.nio.channels.SelectionKey key)
DESCRIBE THE METHOD

Overrides:
read in class SelectionKeyHandler
Parameters:
key - DESCRIBE THE PARAMETER

write

public void write(java.nio.channels.SelectionKey key)
DESCRIBE THE METHOD

Overrides:
write in class SelectionKeyHandler
Parameters:
key - DESCRIBE THE PARAMETER

modifyKey

public void modifyKey(java.nio.channels.SelectionKey key)
DESCRIBE THE METHOD

Overrides:
modifyKey in class SelectionKeyHandler
Parameters:
key - DESCRIBE THE PARAMETER

decodeHeader

public SourceRoute decodeHeader(byte[] header)
                         throws java.io.IOException
Method which adds a header for the provided path to the given data.

Parameters:
header - DESCRIBE THE PARAMETER
Returns:
The messag with a header attached
Throws:
java.io.IOException - DESCRIBE THE EXCEPTION

readHeader

protected void readHeader(java.net.InetSocketAddress address)
                   throws java.io.IOException
Method which processes an incoming message and hands it off to the appropriate handler.

Parameters:
address - DESCRIBE THE PARAMETER
Throws:
java.io.IOException - DESCRIBE THE EXCEPTION

Rice Pastry API

Copyright © 2001-2005 - Rice Pastry.


Imprint-Dataprotection