annotate src/alice/topology/manager/reconnection/CheckConnectionList.java @ 270:23e53aaa8720

reconnect manager worked.
author sugi
date Wed, 21 Aug 2013 15:33:49 +0900
parents 9982e1c4f099
children 3667ab045530
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
269
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
1 package alice.topology.manager.reconnection;
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
2
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
3 import java.util.ArrayList;
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
4 import java.util.HashMap;
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
5 import java.util.List;
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
6
270
23e53aaa8720 reconnect manager worked.
sugi
parents: 269
diff changeset
7 import org.msgpack.type.ValueFactory;
23e53aaa8720 reconnect manager worked.
sugi
parents: 269
diff changeset
8
269
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
9 import alice.codesegment.CodeSegment;
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
10 import alice.datasegment.CommandType;
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
11 import alice.datasegment.Receiver;
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
12 import alice.topology.HostMessage;
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
13
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
14 public class CheckConnectionList extends CodeSegment {
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
15
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
16 private Receiver name = ids.create(CommandType.TAKE);
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
17 private Receiver connection = ids.create(CommandType.TAKE);
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
18 private Receiver abs = ids.create(CommandType.PEEK);
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
19 private Receiver clone = ids.create(CommandType.TAKE);
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
20
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
21 public CheckConnectionList(){
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
22 name.setKey("_RECABSNAME");
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
23 connection.setKey("connection");
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
24 abs.setKey("_ABSIPTABLE");
270
23e53aaa8720 reconnect manager worked.
sugi
parents: 269
diff changeset
25 clone.setKey("_HMCLONE");
269
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
26 }
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
27
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
28 @Override
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
29 public void run() {
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
30 System.out.println("CheckConnectionList");
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
31 @SuppressWarnings("unchecked")
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
32 HashMap<String, ArrayList<HostMessage>> connectionList = connection.asClass(HashMap.class);
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
33 @SuppressWarnings("unchecked")
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
34 List<HostMessage> ABSIPList = abs.asClass(List.class);
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
35 String absName = name.asClass(String.class);
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
36 HostMessage oldInfo = clone.asClass(HostMessage.class);
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
37 HostMessage newInfo = null;
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
38 for (HostMessage mes : ABSIPList){
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
39 if (mes.absName.equals(absName)){
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
40 newInfo = mes;
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
41 break;
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
42 }
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
43 }
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
44
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
45 List<HostMessage> clist = connectionList.get(absName);
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
46 for (HostMessage mes : clist){
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
47 ods.put(absName, mes);
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
48 for (HostMessage mes2 : ABSIPList){
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
49 if (mes.name.equals(mes2.name)&&mes.port == mes2.port){
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
50 String absName2 = mes2.getABSName();
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
51 List<HostMessage> clist2 = connectionList.get(absName2);
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
52 for (HostMessage mes3 : clist2){
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
53 if (mes3.name.equals(oldInfo.name)&&mes3.port == oldInfo.port){
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
54 mes3.name = newInfo.name;
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
55 mes3.port = newInfo.port;
270
23e53aaa8720 reconnect manager worked.
sugi
parents: 269
diff changeset
56 System.out.println(mes3.port);
23e53aaa8720 reconnect manager worked.
sugi
parents: 269
diff changeset
57 System.out.println(mes3.name);
23e53aaa8720 reconnect manager worked.
sugi
parents: 269
diff changeset
58 System.out.println(absName2+" "+newInfo.port);
23e53aaa8720 reconnect manager worked.
sugi
parents: 269
diff changeset
59 ods.put(absName2, "_RECODATA", mes3);
269
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
60 break;
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
61 }
270
23e53aaa8720 reconnect manager worked.
sugi
parents: 269
diff changeset
62
23e53aaa8720 reconnect manager worked.
sugi
parents: 269
diff changeset
63
269
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
64 }
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
65 break;
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
66 }
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
67 }
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
68 }
270
23e53aaa8720 reconnect manager worked.
sugi
parents: 269
diff changeset
69 ods.put(absName, ValueFactory.createNilValue());
23e53aaa8720 reconnect manager worked.
sugi
parents: 269
diff changeset
70
269
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
71
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
72 ods.update("connection", connectionList);
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
73 new ReceiveError();
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
74 }
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
75 }
9982e1c4f099 debugging reconnectManager
sugi
parents:
diff changeset
76