41
|
1 package christie.topology.manager;
|
|
2
|
|
3
|
|
4 import christie.annotation.Peek;
|
|
5 import christie.annotation.Take;
|
|
6 import christie.codegear.CodeGear;
|
|
7 import christie.codegear.CodeGearManager;
|
|
8 import christie.topology.HostMessage;
|
|
9 import org.apache.log4j.Logger;
|
|
10
|
|
11 import java.util.HashMap;
|
|
12 import java.util.LinkedList;
|
|
13
|
|
14 public class IncomingHosts extends CodeGear {
|
|
15
|
44
|
16 @Take // Topology from parse file
|
|
17 HashMap<String, LinkedList<NodeInfo>> resultParse;
|
41
|
18
|
44
|
19 @Take // nodeName list
|
41
|
20 LinkedList<String> nodeNames;
|
|
21
|
|
22 @Take // new coming host info
|
44
|
23 HostMessage newHost;
|
|
24
|
50
|
25 //@Take
|
|
26 @Peek
|
44
|
27 HashMap<String, String> absCookieTable;
|
|
28
|
|
29 @Take
|
|
30 String MD5;
|
41
|
31
|
|
32 private Logger log = Logger.getLogger(IncomingHosts.class);
|
|
33
|
|
34 public IncomingHosts() {
|
|
35
|
|
36 }
|
|
37
|
|
38 @Override
|
57
|
39 protected void run(CodeGearManager cgm) {
|
41
|
40 // not have or match cookie
|
|
41 String nodeName = nodeNames.poll();
|
44
|
42
|
41
|
43 // Manager connect to Node
|
50
|
44 cgm.createRemoteDGM(nodeName, newHost.hostName, newHost.port);
|
41
|
45 getDGM(nodeName).put( "host", nodeName);
|
|
46
|
|
47
|
44
|
48 absCookieTable.put(MD5, nodeName);
|
50
|
49 //getLocalDGM().put("absCookieTable", absCookieTable);
|
41
|
50
|
44
|
51 getDGM(nodeName).put("cookie", MD5);
|
41
|
52 log.info( "toplology manager connected from " + nodeName);
|
|
53
|
44
|
54 LinkedList<NodeInfo> nodeInfoList = resultParse.get(nodeName);
|
|
55 for (NodeInfo nodeInfo : nodeInfoList) {
|
50
|
56 HostMessage hostMessage = new HostMessage(newHost.hostName, newHost.port,
|
41
|
57 nodeInfo.connectionName, nodeInfo.reverseName);
|
44
|
58 hostMessage.absName = nodeName;
|
|
59 hostMessage.remoteAbsName = nodeInfo.sourceNodeName;
|
41
|
60
|
44
|
61 getLocalDGM().put("nodeInfo", hostMessage);
|
57
|
62
|
|
63 // TODO: ここをTopologyNodeのIncommingConnectionInfoにおくれるようにしないと, 動かない.
|
|
64 //getLocalDGM().put("hostInfo", hostMessage);
|
44
|
65 log.info(" write to " + nodeInfo.sourceNodeName + " config message =" + hostMessage.toString() + " remain "
|
41
|
66 + Integer.toString((nodeNames.size())));
|
57
|
67
|
44
|
68 cgm.setup(new RecordTopology());
|
41
|
69 }
|
|
70
|
|
71 log.info(" remaining configure host = " + Integer.toString(nodeNames.size()));
|
|
72 if (nodeNames.isEmpty()) {
|
|
73 // configuration finish
|
44
|
74 for (String key : resultParse.keySet()) {
|
41
|
75 log.info(" write to " + key + " end message =" + (new HostMessage("",0,"","")).toString());
|
57
|
76 getDGM(key).put("hostInfo", new HostMessage("",0,"","")); // end mark
|
41
|
77 }
|
|
78 }
|
|
79
|
44
|
80
|
|
81 getLocalDGM().put("nodeNames", nodeNames);
|
|
82 getLocalDGM().put("resultParse", resultParse);
|
41
|
83
|
|
84 cgm.setup(new IncomingHosts());
|
|
85 }
|
|
86 }
|