mirror of
https://github.com/woodchen-ink/Random-Api.git
synced 2025-07-18 14:02:03 +08:00
禁用日志压缩,日志内容排版
This commit is contained in:
parent
e986e12f37
commit
4b8750edc2
@ -23,38 +23,45 @@ const csvCache = new LRU({
|
|||||||
maxAge: 1000 * 60 * 60 * 24 // 缓存24小时
|
maxAge: 1000 * 60 * 60 * 24 // 缓存24小时
|
||||||
});
|
});
|
||||||
|
|
||||||
//日志格式
|
//日志名称格式
|
||||||
const consoleFormat = winston.format.printf(({ level, message, timestamp }) => {
|
const consoleFormat = winston.format.printf(({ level, message, timestamp }) => {
|
||||||
return `${timestamp} ${level}: ${message}`;
|
return `${timestamp} ${level}: ${message}`;
|
||||||
});
|
});
|
||||||
|
// 自定义日志格式
|
||||||
|
const customFormat = winston.format.printf(({ level, message, timestamp, ...metadata }) => {
|
||||||
|
let msg = `${timestamp} [${level}]: `;
|
||||||
|
|
||||||
|
if (typeof message === 'object') {
|
||||||
|
msg += JSON.stringify(message, null, 2);
|
||||||
|
} else {
|
||||||
|
msg += message;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (metadata.logs) {
|
||||||
|
msg += '\n' + metadata.logs.map(log => JSON.stringify(log, null, 2)).join('\n');
|
||||||
|
}
|
||||||
|
|
||||||
|
return msg;
|
||||||
|
});
|
||||||
// 设置日志
|
// 设置日志
|
||||||
const logger = winston.createLogger({
|
const logger = winston.createLogger({
|
||||||
level: 'info',
|
level: 'info',
|
||||||
format: winston.format.combine(
|
format: winston.format.combine(
|
||||||
winston.format.timestamp(),
|
winston.format.timestamp({ format: 'YYYY-MM-DD HH:mm:ss' }),
|
||||||
winston.format.json()
|
customFormat
|
||||||
),
|
),
|
||||||
transports: [
|
transports: [
|
||||||
new winston.transports.Console({
|
new winston.transports.Console(),
|
||||||
format: winston.format.combine(
|
|
||||||
winston.format.timestamp(),
|
|
||||||
consoleFormat
|
|
||||||
),
|
|
||||||
}),
|
|
||||||
new winston.transports.DailyRotateFile({
|
new winston.transports.DailyRotateFile({
|
||||||
filename: 'logs/application-%DATE%.log',
|
filename: 'logs/application-%DATE%.log',
|
||||||
datePattern: 'YYYY-MM-DD-HH',
|
datePattern: 'YYYY-MM-DD-HH',
|
||||||
zippedArchive: true,
|
|
||||||
maxSize: '20m',
|
maxSize: '20m',
|
||||||
maxFiles: '14d'
|
maxFiles: '7d', //日志保存的时间,超过这个时间的会自动删除旧文件
|
||||||
|
zippedArchive: false // 禁用压缩
|
||||||
})
|
})
|
||||||
]
|
]
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
// 使用压缩中间件
|
|
||||||
app.use(compression());
|
|
||||||
|
|
||||||
// 日志缓冲
|
// 日志缓冲
|
||||||
let logBuffer = [];
|
let logBuffer = [];
|
||||||
|
|
||||||
@ -75,7 +82,7 @@ app.use((req, res, next) => {
|
|||||||
};
|
};
|
||||||
|
|
||||||
// 立即输出到控制台
|
// 立即输出到控制台
|
||||||
console.log(JSON.stringify(logEntry));
|
logger.info(logEntry);
|
||||||
|
|
||||||
// 添加到缓冲区,用于每小时写入文件
|
// 添加到缓冲区,用于每小时写入文件
|
||||||
logBuffer.push(logEntry);
|
logBuffer.push(logEntry);
|
||||||
@ -83,7 +90,7 @@ app.use((req, res, next) => {
|
|||||||
next();
|
next();
|
||||||
});
|
});
|
||||||
|
|
||||||
// 每小时输出一次日志
|
// 每小时输出一次日志到文件
|
||||||
setInterval(() => {
|
setInterval(() => {
|
||||||
if (logBuffer.length > 0) {
|
if (logBuffer.length > 0) {
|
||||||
logger.info('Hourly log', { logs: logBuffer });
|
logger.info('Hourly log', { logs: logBuffer });
|
||||||
|
Loading…
x
Reference in New Issue
Block a user