-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathlogger.js
More file actions
92 lines (85 loc) · 2.99 KB
/
logger.js
File metadata and controls
92 lines (85 loc) · 2.99 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
83
84
85
86
87
88
89
90
91
92
// const { createLogger, format, transports } = require('winston');
// const { combine, label, printf } = format;
// const path = require('path');
// const mt = require('moment-timezone');
// const date = mt().tz('America/Los_Angeles'); // NOTE: 날짜는 한국 시간으로 하고 싶다.
// const myFormat = printf(info => `${info.timestamp} [${info.level}]: ${info.label} - ${info.message}`); // NOTE: 로그 형식 설정
// const koreaTime = format((info) => { // NOTE: 한국 시간으로 하기 위해.. 설정을 안 할 시 에는 UTC 0이 default다.
// info.timestamp = date.format();
// return info;
// });
// const logType = { // 걍 만들어본 서비스 enum
// 1: 'join',
// 2: 'login',
// 3: 'GET',
// 4: 'system',
// };
// const appLogger = (type) => { // NOTE: application log를 남기기 위함.
// const init = createLogger({
// format: combine(
// label({ label: logType[type] }), // NOTE: 어떤 서비스인지 알기 위함
// koreaTime(),
// myFormat,
// ),
// transports: [
// new transports.File({ filename: path.join(__dirname, 'logs', 'app-error.log'), level: 'error' }), // NOTE: 에러는 별도로 보기 위함
// new transports.File({ filename: path.join(__dirname, `logs`, date.format('YYYY-MM-DD'), 'app.log') }), // NOTE: 모든 로그 (에러 포함)
// ],
// });
// if (process.env.NODE_ENV !== 'production') { // NOTE: 실제 서비스 환경이 아닐 시에는 출력을 해야 바로 바로 보기 편함.
// init.add(new transports.Console());
// }
// return init;
// };
// const httpLogger = createLogger({ // NOTE: http status 로그를 남기기 위함.
// format: combine(
// label({ label: 'http' }),
// koreaTime(),
// myFormat,
// ),
// transports: [
// new transports.File({ filename: path.join(__dirname, 'logs', date.format('YYYY-MM-DD'), 'http.log') }),
// ],
// });
// const httpLogStream = {
// write: (message) => { // NOTE: morgan에서 쓰기 위해 이 형태로 fix 되야함.
// httpLogger.log({
// level: 'info',
// message: message,
// });
// },
// };
// exports.appLogger = appLogger;
// exports.httpLogStream = httpLogStream;
const winston = require('winston');
const { createLogger, format, transports } = require('winston');
const winstonDaily = require('winston-daily-rotate-file');
const { combine, timestamp, printf } = format;
// const customFormat = printf(info => {
// return `${info.timestamp}, ${info.message}`;
// });
const logger = winston.createLogger({
format: combine(
winston.format.json()
// timestamp({
// format: 'YYYY-MM-DD HH:mm:ss',
// }),
// customFormat
),
transports: [
new winstonDaily({
level: 'info',
datePattern: 'YYYYMMDD',
dirname: './logs',
filename: `WebLog_%DATE%.log`,
maxSize: null,
maxFiles: 14 //14개 저장-> 즉, 14일
}),
],
});
const stream = {
write: message => {
logger.info(message);
}
};
module.exports = { logger, stream };