KademliaDHT/src/kademlia/operation/BucketRefreshOperation.java

67 lines
2.2 KiB
Java
Raw Normal View History

package kademlia.operation;
import java.io.IOException;
import kademlia.KademliaNode;
import kademlia.core.KadConfiguration;
import kademlia.core.KadServer;
import kademlia.node.NodeId;
/**
* At each time interval t, nodes need to refresh their K-Buckets
* This operation takes care of refreshing this node's K-Buckets
*
* @author Joshua Kissoon
* @created 20140224
*/
public class BucketRefreshOperation implements Operation
{
private final KadServer server;
private final KademliaNode localNode;
private final KadConfiguration config;
public BucketRefreshOperation(KadServer server, KademliaNode localNode, KadConfiguration config)
{
this.server = server;
this.localNode = localNode;
this.config = config;
}
2014-03-06 10:54:50 +00:00
/**
* Each bucket need to be refreshed at every time interval t.
* Find an identifier in each bucket's range, use it to look for nodes closest to this identifier
* allowing the bucket to be refreshed.
*
* Then Do a NodeLookupOperation for each of the generated NodeIds,
* This will find the K-Closest nodes to that ID, and update the necessary K-Bucket
*
* @throws java.io.IOException
*/
@Override
public synchronized void execute() throws IOException
{
2014-03-06 10:54:50 +00:00
for (int i = 1; i < NodeId.ID_LENGTH; i++)
{
2014-03-06 10:54:50 +00:00
/* Construct a NodeId that is i bits away from the current node Id */
final NodeId current = this.localNode.getNode().getNodeId().generateNodeIdByDistance(i);
/* Run the Node Lookup Operation, each in a different thread to speed up things */
new Thread()
{
@Override
public void run()
{
try
{
new NodeLookupOperation(server, localNode, localNode.getNode().getNodeId(), BucketRefreshOperation.this.config).execute();
}
catch (IOException e)
{
System.err.println("Bucket Refresh Operation Failed. Msg: " + e.getMessage());
}
}
}.start();
2014-03-06 10:54:50 +00:00
}
}
}