FEAT: Garantir a criação do diretório de logs e refatorar a configuração do logger
This commit is contained in:
parent
f3f163b85c
commit
22d4324134
@ -1,9 +1,13 @@
|
|||||||
const winston = require('winston');
|
const winston = require('winston');
|
||||||
const path = require('path');
|
const path = require('path');
|
||||||
require('winston-daily-rotate-file');
|
require('winston-daily-rotate-file');
|
||||||
|
const fs = require('fs');
|
||||||
|
|
||||||
// O diretório de logs é criado pelo script de inicialização, mas garantimos aqui também.
|
// verifica se a pasta de logs existe, se não, cria
|
||||||
const logsDir = path.resolve(process.cwd(), 'logs');
|
const logsDir = path.join(__dirname, '../../logs');
|
||||||
|
if (!fs.existsSync(logsDir)) {
|
||||||
|
fs.mkdirSync(logsDir, { recursive: true });
|
||||||
|
}
|
||||||
|
|
||||||
// Configuração do logger com winston
|
// Configuração do logger com winston
|
||||||
const logger = winston.createLogger({
|
const logger = winston.createLogger({
|
||||||
@ -12,7 +16,7 @@ const logger = winston.createLogger({
|
|||||||
winston.format.timestamp({
|
winston.format.timestamp({
|
||||||
format: 'YYYY-MM-DD HH:mm:ss'
|
format: 'YYYY-MM-DD HH:mm:ss'
|
||||||
}),
|
}),
|
||||||
winston.format.errors({ stack: true }), // Mostra stack trace de erros
|
winston.format.errors({ stack: true }), // ← Mostra stack trace de erros
|
||||||
winston.format.json()
|
winston.format.json()
|
||||||
),
|
),
|
||||||
transports: [
|
transports: [
|
||||||
@ -23,6 +27,9 @@ const logger = winston.createLogger({
|
|||||||
zippedArchive: true,
|
zippedArchive: true,
|
||||||
maxSize: '5m',
|
maxSize: '5m',
|
||||||
maxFiles: '10d',
|
maxFiles: '10d',
|
||||||
|
options: {
|
||||||
|
flags: 'w' // Usa 'w' para sobrescrever o arquivo no início de cada dia
|
||||||
|
}
|
||||||
}),
|
}),
|
||||||
// Log de erros
|
// Log de erros
|
||||||
new winston.transports.DailyRotateFile({
|
new winston.transports.DailyRotateFile({
|
||||||
@ -32,12 +39,16 @@ const logger = winston.createLogger({
|
|||||||
zippedArchive: true,
|
zippedArchive: true,
|
||||||
maxSize: '5m',
|
maxSize: '5m',
|
||||||
maxFiles: '10d',
|
maxFiles: '10d',
|
||||||
|
options: {
|
||||||
|
flags: 'w' // Usa 'w' para sobrescrever o arquivo no início de cada dia
|
||||||
|
}
|
||||||
})
|
})
|
||||||
],
|
],
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
// Log no console em desenvolvimento
|
// Adiciona o log no console para TODOS os ambientes (desenvolvimento e produção).
|
||||||
if (process.env.NODE_ENV !== 'production') {
|
// Isso é essencial para que o `pm2 logs` funcione corretamente.
|
||||||
logger.add(new winston.transports.Console({
|
logger.add(new winston.transports.Console({
|
||||||
format: winston.format.combine(
|
format: winston.format.combine(
|
||||||
winston.format.colorize(),
|
winston.format.colorize(),
|
||||||
@ -51,9 +62,31 @@ if (process.env.NODE_ENV !== 'production') {
|
|||||||
})
|
})
|
||||||
)
|
)
|
||||||
}));
|
}));
|
||||||
}
|
|
||||||
|
|
||||||
module.exports = logger;
|
// Funções utilitárias
|
||||||
|
const logError = (error, context = '') => {
|
||||||
|
if (error instanceof Error) {
|
||||||
|
logger.error(`${context} - ${error.message}`, { stack: error.stack });
|
||||||
|
} else {
|
||||||
|
logger.error(`${context} - ${error}`);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
const logInfo = (message, meta = {}) => {
|
||||||
|
logger.info(message, meta);
|
||||||
|
};
|
||||||
|
|
||||||
|
const logWarning = (message, meta = {}) => {
|
||||||
|
logger.warn(message, meta);
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
module.exports = {
|
||||||
|
logger,
|
||||||
|
logError,
|
||||||
|
logInfo,
|
||||||
|
logWarning
|
||||||
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
DESCRIÇÃO:
|
DESCRIÇÃO:
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user