-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathlooger.js
74 lines (64 loc) · 2.11 KB
/
looger.js
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
let winston = require('winston');
let cluster = require('cluster');
let config = {
logs: {
level: "debug",
maxFiles = 10,
fileMaxSize: 1000 * 1000 * 100 //100MB,
folder: "."
}
}
if (cluster.isMaster) {
const genTimestamp = () => (new Date().toLocaleDateString()) + ' ' + (new Date() ).toLocaleTimeString();
const genLogRow = (options) => {
// Return string will be passed to logger.
return options.level.toUpperCase() + ' ' + options.timestamp() + ' ' + (options.message ? options.message : '') +
(options.meta && Object.keys(options.meta).length ? " " + JSON.stringify(options.meta) : '' );
};
winston.remove(winston.transports.Console);
winston.add(winston.transports.Console, {
colorize: true,
json: false,
level: config.logs.level,
timestamp: genTimestamp,
formatter: genLogRow
});
winston.add(winston.transports.File, {
filename: `${config.logs.folder}\/ds.log`,
maxsize: config.logs.fileMaxSize,
maxFiles: config.logs.maxFiles,
tailable: true,
level: config.logs.level,
json: false,
timestamp: genTimestamp,
formatter: genLogRow
});
cluster.on("message", (info, message) => {
if (message.type == "logging") {
loggingMessageHandler(message.data)
}
});
loggingMessageHandler = (data) => {
winston.log(data.level, data.message)
};
module.exports = winston;
}
else {
const sendToMaster = (level, message) => {
process.send({
type: "logging",
data: {level, message}
});
};
module.exports = {
error: message => {
sendToMaster("error", message)
},
warn: message => sendToMaster("warn", message),
info: message => sendToMaster("info", message),
verbose: message => sendToMaster("verbose", message),
debug: message => sendToMaster("debug", message),
silly: message => sendToMaster("silly", message),
log: (level, message) => sendToMaster(level, message)
};
}