annotate src/main/java/christie/topology/manager/keepalive/TaskExecuter.java @ 168:c7300be0fff6

fix incomingHosts end message
author akahori
date Tue, 22 Jan 2019 16:00:29 +0900
parents fd944876257b
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
49
fd944876257b add node and keepalive
akahori
parents:
diff changeset
1 package christie.topology.manager.keepalive;
fd944876257b add node and keepalive
akahori
parents:
diff changeset
2
fd944876257b add node and keepalive
akahori
parents:
diff changeset
3 import christie.annotation.Take;
fd944876257b add node and keepalive
akahori
parents:
diff changeset
4 import christie.codegear.CodeGear;
fd944876257b add node and keepalive
akahori
parents:
diff changeset
5 import christie.codegear.CodeGearManager;
fd944876257b add node and keepalive
akahori
parents:
diff changeset
6
fd944876257b add node and keepalive
akahori
parents:
diff changeset
7 public class TaskExecuter extends CodeGear {
fd944876257b add node and keepalive
akahori
parents:
diff changeset
8
fd944876257b add node and keepalive
akahori
parents:
diff changeset
9 @Take
fd944876257b add node and keepalive
akahori
parents:
diff changeset
10 ListManager _SCHEDULER;
fd944876257b add node and keepalive
akahori
parents:
diff changeset
11 private TaskInfo nowTask;
fd944876257b add node and keepalive
akahori
parents:
diff changeset
12 private boolean sleepFlag = false;
fd944876257b add node and keepalive
akahori
parents:
diff changeset
13 private boolean skipFlag = false;
fd944876257b add node and keepalive
akahori
parents:
diff changeset
14 private long startTime = 0;
fd944876257b add node and keepalive
akahori
parents:
diff changeset
15 private long remainingTime = 0;
fd944876257b add node and keepalive
akahori
parents:
diff changeset
16 private static TaskExecuter instance = new TaskExecuter();
fd944876257b add node and keepalive
akahori
parents:
diff changeset
17
fd944876257b add node and keepalive
akahori
parents:
diff changeset
18 private TaskExecuter() {
fd944876257b add node and keepalive
akahori
parents:
diff changeset
19 }
fd944876257b add node and keepalive
akahori
parents:
diff changeset
20
fd944876257b add node and keepalive
akahori
parents:
diff changeset
21 public static TaskExecuter getInstance() {
fd944876257b add node and keepalive
akahori
parents:
diff changeset
22 return instance;
fd944876257b add node and keepalive
akahori
parents:
diff changeset
23 }
fd944876257b add node and keepalive
akahori
parents:
diff changeset
24
fd944876257b add node and keepalive
akahori
parents:
diff changeset
25 public void taskExecutorSetKey() {
fd944876257b add node and keepalive
akahori
parents:
diff changeset
26 //ids.init();
fd944876257b add node and keepalive
akahori
parents:
diff changeset
27 }
fd944876257b add node and keepalive
akahori
parents:
diff changeset
28
fd944876257b add node and keepalive
akahori
parents:
diff changeset
29
fd944876257b add node and keepalive
akahori
parents:
diff changeset
30 @Override
fd944876257b add node and keepalive
akahori
parents:
diff changeset
31 protected synchronized void run(CodeGearManager cgm) {
fd944876257b add node and keepalive
akahori
parents:
diff changeset
32 if (_SCHEDULER.getTaskList().size() == 0) {
fd944876257b add node and keepalive
akahori
parents:
diff changeset
33 TaskInfo task = new TaskInfo(TaskType.CREATE);
fd944876257b add node and keepalive
akahori
parents:
diff changeset
34 task.setSleepTime(3000);
fd944876257b add node and keepalive
akahori
parents:
diff changeset
35 _SCHEDULER.addTask(task);
fd944876257b add node and keepalive
akahori
parents:
diff changeset
36 getLocalDGM().put("_SCHEDULER", _SCHEDULER);
fd944876257b add node and keepalive
akahori
parents:
diff changeset
37 remainingTime = 0;
fd944876257b add node and keepalive
akahori
parents:
diff changeset
38 return;
fd944876257b add node and keepalive
akahori
parents:
diff changeset
39 }
fd944876257b add node and keepalive
akahori
parents:
diff changeset
40
fd944876257b add node and keepalive
akahori
parents:
diff changeset
41 nowTask = _SCHEDULER.getTaskList().poll();
fd944876257b add node and keepalive
akahori
parents:
diff changeset
42 if (nowTask.getType() != TaskType.PING)
fd944876257b add node and keepalive
akahori
parents:
diff changeset
43 getLocalDGM().put("_SCHEDULER", _SCHEDULER);
fd944876257b add node and keepalive
akahori
parents:
diff changeset
44 if (skipFlag) {
fd944876257b add node and keepalive
akahori
parents:
diff changeset
45 skipFlag = false;
fd944876257b add node and keepalive
akahori
parents:
diff changeset
46 nowTask.setSleepTime(remainingTime + nowTask.getSleepTime());
fd944876257b add node and keepalive
akahori
parents:
diff changeset
47 remainingTime = 0;
fd944876257b add node and keepalive
akahori
parents:
diff changeset
48 }
fd944876257b add node and keepalive
akahori
parents:
diff changeset
49 startTime = System.currentTimeMillis();
fd944876257b add node and keepalive
akahori
parents:
diff changeset
50 if (nowTask.getSleepTime() != 0) {
fd944876257b add node and keepalive
akahori
parents:
diff changeset
51 sleepFlag = true;
fd944876257b add node and keepalive
akahori
parents:
diff changeset
52 try {
fd944876257b add node and keepalive
akahori
parents:
diff changeset
53 wait(nowTask.getSleepTime());
fd944876257b add node and keepalive
akahori
parents:
diff changeset
54 } catch (InterruptedException e) {
fd944876257b add node and keepalive
akahori
parents:
diff changeset
55 e.printStackTrace();
fd944876257b add node and keepalive
akahori
parents:
diff changeset
56 }
fd944876257b add node and keepalive
akahori
parents:
diff changeset
57 sleepFlag = false;
fd944876257b add node and keepalive
akahori
parents:
diff changeset
58 }
fd944876257b add node and keepalive
akahori
parents:
diff changeset
59
fd944876257b add node and keepalive
akahori
parents:
diff changeset
60 if (!skipFlag) {
fd944876257b add node and keepalive
akahori
parents:
diff changeset
61 // ping or close
fd944876257b add node and keepalive
akahori
parents:
diff changeset
62 if (nowTask.getType() == TaskType.PING) {
fd944876257b add node and keepalive
akahori
parents:
diff changeset
63 //ods.ping(nowTask.getManagerKey(), nowTask.getReturnKey());
fd944876257b add node and keepalive
akahori
parents:
diff changeset
64 TaskInfo task = new TaskInfo(TaskType.CLOSE);
fd944876257b add node and keepalive
akahori
parents:
diff changeset
65 task.setInfo(nowTask.getManagerKey(), 10 * 1000);
fd944876257b add node and keepalive
akahori
parents:
diff changeset
66 _SCHEDULER.addTask(task);
fd944876257b add node and keepalive
akahori
parents:
diff changeset
67 getLocalDGM().put("_SCHEDULER", _SCHEDULER);
fd944876257b add node and keepalive
akahori
parents:
diff changeset
68 cgm.setup(new RespondPing());
fd944876257b add node and keepalive
akahori
parents:
diff changeset
69 } else if (nowTask.getType() == TaskType.CLOSE) {
fd944876257b add node and keepalive
akahori
parents:
diff changeset
70 // TODO: shotdown処理は後で追加する.
fd944876257b add node and keepalive
akahori
parents:
diff changeset
71 /* // no response from the Remote DataSegment. So close this connection.
fd944876257b add node and keepalive
akahori
parents:
diff changeset
72 if (DataSegment.contains(nowTask.getManagerKey())) {
fd944876257b add node and keepalive
akahori
parents:
diff changeset
73 DataSegment.get(nowTask.getManagerKey()).shutdown();
fd944876257b add node and keepalive
akahori
parents:
diff changeset
74 System.out.println(nowTask.getManagerKey() +" IS SHOTDOWN");
fd944876257b add node and keepalive
akahori
parents:
diff changeset
75 } else {
fd944876257b add node and keepalive
akahori
parents:
diff changeset
76 System.out.println(nowTask.getManagerKey() +" IS ALREADY SHOTDOWN");
fd944876257b add node and keepalive
akahori
parents:
diff changeset
77 }*/
fd944876257b add node and keepalive
akahori
parents:
diff changeset
78
fd944876257b add node and keepalive
akahori
parents:
diff changeset
79 } else if (nowTask.getType() == TaskType.CREATE) {
fd944876257b add node and keepalive
akahori
parents:
diff changeset
80 cgm.setup(new CreateTask());
fd944876257b add node and keepalive
akahori
parents:
diff changeset
81 }
fd944876257b add node and keepalive
akahori
parents:
diff changeset
82 }
fd944876257b add node and keepalive
akahori
parents:
diff changeset
83 nowTask = null;
fd944876257b add node and keepalive
akahori
parents:
diff changeset
84 startTime = 0;
fd944876257b add node and keepalive
akahori
parents:
diff changeset
85
fd944876257b add node and keepalive
akahori
parents:
diff changeset
86
fd944876257b add node and keepalive
akahori
parents:
diff changeset
87 // taskExecutorSetKey();
fd944876257b add node and keepalive
akahori
parents:
diff changeset
88 }
fd944876257b add node and keepalive
akahori
parents:
diff changeset
89
fd944876257b add node and keepalive
akahori
parents:
diff changeset
90 public synchronized void skip() {
fd944876257b add node and keepalive
akahori
parents:
diff changeset
91 if (sleepFlag) {
fd944876257b add node and keepalive
akahori
parents:
diff changeset
92 skipFlag = true;
fd944876257b add node and keepalive
akahori
parents:
diff changeset
93 if (startTime == 0) {
fd944876257b add node and keepalive
akahori
parents:
diff changeset
94 remainingTime = nowTask.getSleepTime();
fd944876257b add node and keepalive
akahori
parents:
diff changeset
95 } else {
fd944876257b add node and keepalive
akahori
parents:
diff changeset
96 remainingTime = nowTask.getSleepTime() - (System.currentTimeMillis() - startTime);
fd944876257b add node and keepalive
akahori
parents:
diff changeset
97 }
fd944876257b add node and keepalive
akahori
parents:
diff changeset
98 nowTask = null;
fd944876257b add node and keepalive
akahori
parents:
diff changeset
99 notify();
fd944876257b add node and keepalive
akahori
parents:
diff changeset
100 }
fd944876257b add node and keepalive
akahori
parents:
diff changeset
101 }
fd944876257b add node and keepalive
akahori
parents:
diff changeset
102
fd944876257b add node and keepalive
akahori
parents:
diff changeset
103 public synchronized void ignore() {
fd944876257b add node and keepalive
akahori
parents:
diff changeset
104 if (sleepFlag) {
fd944876257b add node and keepalive
akahori
parents:
diff changeset
105 skipFlag = true;
fd944876257b add node and keepalive
akahori
parents:
diff changeset
106 remainingTime = 0;
fd944876257b add node and keepalive
akahori
parents:
diff changeset
107 nowTask = null;
fd944876257b add node and keepalive
akahori
parents:
diff changeset
108 notify();
fd944876257b add node and keepalive
akahori
parents:
diff changeset
109 }
fd944876257b add node and keepalive
akahori
parents:
diff changeset
110 }
fd944876257b add node and keepalive
akahori
parents:
diff changeset
111
fd944876257b add node and keepalive
akahori
parents:
diff changeset
112 public synchronized TaskInfo getNowTask() {
fd944876257b add node and keepalive
akahori
parents:
diff changeset
113 return nowTask;
fd944876257b add node and keepalive
akahori
parents:
diff changeset
114 }
fd944876257b add node and keepalive
akahori
parents:
diff changeset
115
fd944876257b add node and keepalive
akahori
parents:
diff changeset
116 // only use in ListManagerTest
fd944876257b add node and keepalive
akahori
parents:
diff changeset
117 public synchronized void setNowTask(TaskInfo info) {
fd944876257b add node and keepalive
akahori
parents:
diff changeset
118 nowTask = info;
fd944876257b add node and keepalive
akahori
parents:
diff changeset
119 }
fd944876257b add node and keepalive
akahori
parents:
diff changeset
120
fd944876257b add node and keepalive
akahori
parents:
diff changeset
121 public synchronized long getRemainingTime() {
fd944876257b add node and keepalive
akahori
parents:
diff changeset
122 if (sleepFlag) {
fd944876257b add node and keepalive
akahori
parents:
diff changeset
123 if (startTime != 0) {
fd944876257b add node and keepalive
akahori
parents:
diff changeset
124 return nowTask.getSleepTime() - (System.currentTimeMillis() - startTime);
fd944876257b add node and keepalive
akahori
parents:
diff changeset
125 } else {
fd944876257b add node and keepalive
akahori
parents:
diff changeset
126 return nowTask.getSleepTime();
fd944876257b add node and keepalive
akahori
parents:
diff changeset
127 }
fd944876257b add node and keepalive
akahori
parents:
diff changeset
128 } else {
fd944876257b add node and keepalive
akahori
parents:
diff changeset
129 return remainingTime;
fd944876257b add node and keepalive
akahori
parents:
diff changeset
130 }
fd944876257b add node and keepalive
akahori
parents:
diff changeset
131 }
fd944876257b add node and keepalive
akahori
parents:
diff changeset
132
fd944876257b add node and keepalive
akahori
parents:
diff changeset
133 public synchronized boolean compareAndSkip(TaskInfo task) {
fd944876257b add node and keepalive
akahori
parents:
diff changeset
134 if (nowTask != null) {
fd944876257b add node and keepalive
akahori
parents:
diff changeset
135 if (nowTask.getType().equals(task.getType())
fd944876257b add node and keepalive
akahori
parents:
diff changeset
136 && nowTask.getManagerKey().equals(task.getManagerKey())) {
fd944876257b add node and keepalive
akahori
parents:
diff changeset
137 skip();
fd944876257b add node and keepalive
akahori
parents:
diff changeset
138 return true;
fd944876257b add node and keepalive
akahori
parents:
diff changeset
139 }
fd944876257b add node and keepalive
akahori
parents:
diff changeset
140 }
fd944876257b add node and keepalive
akahori
parents:
diff changeset
141 return false;
fd944876257b add node and keepalive
akahori
parents:
diff changeset
142 }
fd944876257b add node and keepalive
akahori
parents:
diff changeset
143
fd944876257b add node and keepalive
akahori
parents:
diff changeset
144 }