annotate src/main/java/alice/daemon/IncomingTcpConnection.java @ 363:3c9446fa4073 multicast

remove no need method
author sugi
date Fri, 16 May 2014 16:50:38 +0900
parents 11ba40caa93b
children 8072df9130c6
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
345
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
1 package alice.daemon;
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
2
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
3 import java.io.EOFException;
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
4 import java.io.IOException;
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
5 import java.nio.channels.ClosedChannelException;
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
6
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
7 import org.msgpack.unpacker.Unpacker;
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
8
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
9 import alice.codesegment.SingletonMessage;
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
10 import alice.datasegment.Command;
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
11 import alice.datasegment.CommandType;
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
12 import alice.datasegment.DataSegment;
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
13 import alice.datasegment.DataSegmentManager;
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
14 import alice.datasegment.LocalDataSegmentManager;
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
15 import alice.topology.HostMessage;
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
16 import alice.topology.manager.keeparive.RespondData;
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
17 import alice.topology.manager.reconnection.SendError;
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
18
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
19 public class IncomingTcpConnection extends Thread {
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
20
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
21 public Connection connection;
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
22 public DataSegmentManager manager;
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
23 public String reverseKey;
363
3c9446fa4073 remove no need method
sugi
parents: 359
diff changeset
24 protected LocalDataSegmentManager lmanager = DataSegment.getLocal();
345
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
25
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
26 public IncomingTcpConnection(Connection connection, DataSegmentManager manager, String reverseKey) {
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
27 this.manager = manager;
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
28 this.connection = connection;
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
29 this.reverseKey = reverseKey;
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
30 }
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
31
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
32 /**
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
33 * pipeline thread for receiving
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
34 */
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
35 public void run() {
363
3c9446fa4073 remove no need method
sugi
parents: 359
diff changeset
36 Unpacker unpacker = null;
3c9446fa4073 remove no need method
sugi
parents: 359
diff changeset
37 try {
3c9446fa4073 remove no need method
sugi
parents: 359
diff changeset
38 unpacker = SingletonMessage.getInstance().createUnpacker(connection.socket.getInputStream());
3c9446fa4073 remove no need method
sugi
parents: 359
diff changeset
39 } catch (IOException e) {
3c9446fa4073 remove no need method
sugi
parents: 359
diff changeset
40 e.printStackTrace();
3c9446fa4073 remove no need method
sugi
parents: 359
diff changeset
41 }
345
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
42 if (unpacker == null) {
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
43 return;
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
44 }
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
45 while (true) {
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
46 try {
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
47 CommandMessage msg = unpacker.read(CommandMessage.class);
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
48 CommandType type = CommandType.getCommandTypeFromId(msg.type);
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
49 switch (type) {
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
50 case UPDATE:
359
11ba40caa93b remove no need method
sugi
parents: 345
diff changeset
51 lmanager.getDataSegmentKey(msg.key)
11ba40caa93b remove no need method
sugi
parents: 345
diff changeset
52 .runCommand(new Command(type, null, null, msg.val, 0, 0, null, null, reverseKey));
345
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
53 break;
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
54 case PUT:
359
11ba40caa93b remove no need method
sugi
parents: 345
diff changeset
55 lmanager.getDataSegmentKey(msg.key)
11ba40caa93b remove no need method
sugi
parents: 345
diff changeset
56 .runCommand(new Command(type, null, null, msg.val, 0, 0, null, null, reverseKey));
345
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
57 break;
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
58 case PEEK:
359
11ba40caa93b remove no need method
sugi
parents: 345
diff changeset
59 lmanager.getDataSegmentKey(msg.key)
11ba40caa93b remove no need method
sugi
parents: 345
diff changeset
60 .runCommand(new Command(type, null, null, null, msg.index, msg.seq, connection, null, null, msg.flag));
345
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
61 break;
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
62 case TAKE:
359
11ba40caa93b remove no need method
sugi
parents: 345
diff changeset
63 lmanager.getDataSegmentKey(msg.key)
11ba40caa93b remove no need method
sugi
parents: 345
diff changeset
64 .runCommand(new Command(type, null, null, null, msg.index, msg.seq, connection, null, null, msg.flag));
345
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
65 break;
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
66 case REMOVE:
359
11ba40caa93b remove no need method
sugi
parents: 345
diff changeset
67 lmanager.getDataSegmentKey(msg.key)
11ba40caa93b remove no need method
sugi
parents: 345
diff changeset
68 .runCommand(new Command(type, null, null, null, 0, 0, null, null, null));
345
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
69 break;
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
70 case REPLY:
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
71 Command cmd = manager.getAndRemoveCmd(msg.seq);
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
72 cmd.cs.ids.reply(cmd.receiver, new Command(type, null, null, msg.val, msg.index, msg.seq, null, null, null));
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
73 cmd=null;
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
74 break;
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
75 case PING:
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
76 DataSegment.get(reverseKey).response(msg.key);
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
77 break;
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
78 case RESPONSE:
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
79 DataSegment.getLocal().put(msg.key, new RespondData(reverseKey, System.currentTimeMillis()));
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
80 break;
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
81 default:
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
82 break;
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
83 }
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
84 } catch (ClosedChannelException e) {
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
85 connection.sendCommand(new Command(CommandType.CLOSE, null, null, null, 0, 0, null, null, null));
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
86 return;
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
87 } catch (EOFException e) {
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
88 new SendError(new HostMessage(connection.socket.getInetAddress().getHostName(), connection.socket.getPort())).execute();
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
89 connection.sendCommand(new Command(CommandType.CLOSE, null, null, null, 0, 0, null, null, null));
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
90 return;
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
91 } catch (IOException e) {
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
92 e.printStackTrace();
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
93 }
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
94 }
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
95 }
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
96
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
97 }