-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathClient.java
139 lines (118 loc) · 4.46 KB
/
Client.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
import java.io.*;
import java.net.ServerSocket;
import java.net.Socket;
import java.util.Enumeration;
import java.util.Hashtable;
import java.util.Scanner;
import java.util.concurrent.atomic.AtomicBoolean;
public class Client {
private class ServerStruct{
int id, port;
String serverAddress;
public ServerStruct(int id, String serverAddress, int port){
this.id = id;
this.port = port;
this.serverAddress = serverAddress;
}
}
int serverSize;
int clientSize;
Hashtable<Integer, ServerStruct> servers;
Hashtable<Integer, BufferedReader> readers;
Hashtable<Integer, PrintWriter> writers;
//Library Variables
private AtomicBoolean wait;
private int gettedValue;
private String clientName;
private Thread t;
public Client(String name) {
//Initialize Hashtable
servers = new Hashtable<Integer, ServerStruct>();
readers = new Hashtable<Integer, BufferedReader>();
writers = new Hashtable<Integer, PrintWriter>();
clientName = name;
clientSize = 1;
serverSize = 0;
wait = new AtomicBoolean(true);
}
public void addServer(String serverAddress, int port){
serverSize++;
ServerStruct s = new ServerStruct(serverSize, serverAddress, port);
if(!servers.containsKey(s.id) && !servers.contains(s)){
servers.put(s.id, s);
}
try {
run(s.id, s.serverAddress, s.port);
} catch (IOException e1) {
e1.printStackTrace();
}
}
public int getKey(String key){
int serverIndex = generateIndex(key);
writers.get(serverIndex).println("getkey " + clientName + " " + key + " " + serverIndex);
while(wait.get()){
}
wait.set(true);
return gettedValue;
}
public void putKey(String key, Object val){
int serverIndex = generateIndex(key);
System.err.println("Put: " + key + " : " + val.toString() + " into " + "[" + servers.get(serverIndex).serverAddress
+ ":" + servers.get(serverIndex).port + "]");
writers.get(serverIndex).println("putkey " + key.toString() + " " + val.toString() + " " + serverIndex);
}
public int generateIndex(String key){
int hash = 7;
for (int i = 0; i < key.length(); i++) {
hash = hash*31 + key.charAt(i);
}
int index = hash % serverSize;
return index+1;
}
/**
* Connects to the server then enters the processing loop.
*/
public void run(final int id, String serverAddress, int port) throws IOException {
// Make connection and initialize streams
Socket socket = new Socket(serverAddress, port);
BufferedReader in;
PrintWriter out;
in = new BufferedReader(new InputStreamReader(
socket.getInputStream()));
out = new PrintWriter(socket.getOutputStream(), true);
readers.put(id, in);
writers.put(id, out);
t = new Thread(new Runnable() {
public void run() {
// Process all messages from server, according to the protocol.
while (true) {
String line = null;
try {
line = readers.get(id).readLine();
} catch (IOException e) {
e.printStackTrace();
}
if (line.startsWith("SUBMITNAME")) {
writers.get(id).println(clientName);
} else if (line.startsWith("NAMEACCEPTED")) {
} else if (line.startsWith("MESSAGE")) {
String[] str = line.split(" ");
if(str.length == 3 && str[1].equals("returnsize")){
clientSize = Integer.parseInt(str[2]);
}
else if(str.length == 5 && str[1].equals("getkey")){
System.err.println("[" + str[4] + "]" + " key: " + str[2] + " value: " + str[3] + "\n");
gettedValue = Integer.parseInt(str[3]);
wait.set(false);
}
else{
System.err.println("Undefined command..." + "\n");
}
//System.err.println(line);
}
}
}
});
t.start();
}
}