updated ChatClient.java, added ChordClient.java

git-svn-id: svn://anubis/gvsu@218 45c1a28c-8058-47b2-ae61-ca45b979098e
This commit is contained in:
josh 2008-10-27 22:24:46 +00:00
parent 3d64ba091e
commit 613d3b2ff4
2 changed files with 108 additions and 0 deletions

View File

@ -340,6 +340,9 @@ public class ChatClient
} }
} }
} }
// Load the Chord properties files
PropertiesLoader.loadPropertyFile();
} }
private static void usage() private static void usage()

105
cs656/lab3/ChordClient.java Normal file
View File

@ -0,0 +1,105 @@
/**
* Some sample OpenChord code. See OpenChord manual and javadocs for more detail.
* @author Jonathan Engelsma
*/
import java.net.InetAddress;
import java.net.MalformedURLException;
import de.uniba.wiai.lspi.chord.data.URL;
import de.uniba.wiai.lspi.chord.service.*;
import de.uniba.wiai.lspi.chord.service.impl.*;
import java.util.*;
import java.io.Serializable;
public class ChordClient
{
private Chord myChord;
public Chord chord()
{
return myChord;
}
public ChordClient(String masterHost, boolean master)
{
try
{
if (master)
createNetwork(masterHost);
else
joinNetwork(masterHost);
}
catch (Exception e)
{
e.printStackTrace();
}
}
public void createNetwork(String host)
{
System.out.println("Creating Chord network on \"" + host + "\"");
String protocol = URL.KNOWN_PROTOCOLS.get(URL.SOCKET_PROTOCOL);
URL localURL = null;
try
{
localURL = new URL( protocol + "://" + host + ":4242/");
}
catch (MalformedURLException e)
{
throw new RuntimeException(e);
}
myChord = new ChordImpl();
try
{
myChord.create(localURL);
}
catch (ServiceException e)
{
throw new RuntimeException("Error: Could not create DHT!", e);
}
}
public void joinNetwork(String host)
{
System.out.println("Joining Chord network on \"" + host + "\"");
String protocol = URL.KNOWN_PROTOCOLS.get(URL.SOCKET_PROTOCOL);
URL localURL = null;
try
{
localURL = new URL(protocol + "://" + InetAddress.getLocalHost().getHostAddress() + ":4243/");
}
catch (MalformedURLException e)
{
throw new RuntimeException(e);
}
catch (Exception ex)
{
throw new RuntimeException(ex);
}
URL bootstrapURL = null;
try
{
bootstrapURL = new URL( protocol + "://" + host + ":4242/");
}
catch (MalformedURLException e)
{
throw new RuntimeException (e);
}
myChord = new ChordImpl();
try
{
myChord.join(localURL , bootstrapURL);
}
catch (ServiceException e)
{
throw new RuntimeException("Error: Could not join DHT!", e);
}
}
}