-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathworker_basic.js
More file actions
82 lines (76 loc) · 2.56 KB
/
worker_basic.js
File metadata and controls
82 lines (76 loc) · 2.56 KB
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
var gearmanode = require("gearmanode");
var exec = require("child_process").exec;
var delay = 5;
var die = 0;
// sleep
function timeout(ms) {
return new Promise((resolve) => setTimeout(resolve, ms));
}
var port = 4730 + Number(process.argv[2]);
var worker = gearmanode.worker({ port: port });
worker.addFunction("sum", sumFunction);
worker.addFunction("count", countFunction);
worker.on('socketDisconnect', disconnectFunction);
async function sumFunction(job) {
var [input, startTime] = JSON.parse(job.payload);
var output = [];
for (var i = 0; i < input.length; i++) {
var temp = input[i];
var sum = 0;
for (var j = 0; j < temp.length; j++) {
if (die)
return;
sum += temp[j][1];
await timeout(delay);
console.log(
`SUM : ${i + 1}/${input.length} ${j + 1}/${temp.length
} --- ${delay}ms per 1 operation`
);
}
output.push([temp[0][0], sum]); // [studentId, totalScore]
}
console.log("------------SUM OUTPUT------------");
console.log(output);
job.workComplete(JSON.stringify([output, startTime]));
}
async function countFunction(job) {
var [input, startTime] = JSON.parse(job.payload);
var output = [];
for (var i = 0; i <= 100; i++) {
output.push([i, 0]);
}
for (var i = 0; i < input.length; i++) {
if (die)
return;
output[input[i][1]][1]++;
await timeout(delay);
console.log(
`COUNT ${i + 1}/${input.length} --- ${delay}ms per 1 operation`
);
}
console.log("------------COUNT OUTPUT------------");
console.log(output);
job.workComplete(JSON.stringify([output, startTime]));
}
// Worker FT
async function disconnectFunction() {
die = true;
console.log('[ERROR] Server Died. Trying to Restart Server');
let command = 'pm2 start -f ' + __dirname + '/server.js -- ' + process.argv[2];
exec(command, async function (error, stdout, stderr) {
if (error == null) {
console.log('----Successfully Restarted Server----');
await timeout(1000); // Time to Start pm2 service
die = false;
// Reset Server
worker = gearmanode.worker({ port: port });
worker.addFunction("sum", sumFunction);
worker.addFunction("count", countFunction);
worker.on('socketDisconnect', disconnectFunction);
} else {
console.log("exec error: " + error);
}
});
// await timeout(1000);
// die = false;
}