gpt4 book ai didi

mysql - 如何在 Node.js 中使用 express-winston 将日志存储到 mysql db

转载 作者:行者123 更新时间:2023-12-03 22:20:35 41 4
gpt4 key购买 nike

我正在尝试使用 Node.js 中的 express-winston 将日志存储到 mysql db(使用 Sequelize)中。
根据 doc( https://www.npmjs.com/package/winston-sql-transport ),我应该执行以下操作:

const { Logger } = require('winston');
const { SQLTransport } = require('./../lib/winston-sql-transport');

const logger = new Logger({
transports: [
new SQLTransport({
tableName: 'winston_logs',
})]
});

module.exports = logger;
我在 app.js 中应用了上面的代码,但没有成功。
应用程序.js
const { SQLTransport } = require('./../lib/winston-sql-transport'); // //Error: Cannot find module './../lib/winston-sql-transport'

const mysqlOption = {
tableName: 'winston_logs'
}

app.use(
expressWinston.logger({
transports: [
new SQLTransport(mysqlOption)
],
format: winston.format.combine(
winston.format.timestamp({ format: timezoned }),
winston.format.json(),
),
metaField: null,
expressFormat: true,
statusLevels: false,
level: function (req, res) {
var level = "";
if (res.statusCode < 400) { level = "info"; }
if (res.statusCode >= 400) { level = "warn"; }
if (res.statusCode >= 500) { level = "error"; }
return level;
}
})
)

我试图将导入更改为 const { SQLTransport } = require('winston-sql-transport');结果错误:
Error: You have to define client

at new SQLTransport (/server/node_modules/winston-sql-transport/lib/winston-sql-transport.js:40:13)
我发现人们很少谈论这个包。
所以我想知道有没有办法做到这一点?
更新 1:
我按照评论的建议更新了 mysqlOption
const { SQLTransport } = require('winston-sql-transport'); 

const mysqlOption = {
tableName : "winston_logs",
client: 'mysql',
connection: {
host: '127.0.0.1:3306',
user: 'root',
password: '',
database: 'mydb'
}
}
日志成功出现在控制台中,但没有存储在我的数据库中。
更新 2:
由于我使用 Sequelize,我将提供日志表的架构
// See http://docs.sequelizejs.com/en/latest/docs/models-definition/
// for more of what you can do here.
const Sequelize = require('sequelize');
const DataTypes = Sequelize.DataTypes;

module.exports = function (app) {
const sequelizeClient = app.get('sequelizeClient');
const logs = sequelizeClient.define('winston_logs', {
id: {
type: DataTypes.INTEGER(10),
allowNull: false,
autoIncrement: true,
primaryKey: true
},
level: {
type: DataTypes.STRING(45),
allowNull: false
},
message: {
type: DataTypes.TEXT,
allowNull: false
},
meta: {
type: DataTypes.STRING(255),
allowNull: false
},
hostname: {
type: DataTypes.STRING(255),
allowNull: false
},
timestamp: {
type: DataTypes.DATE,
allowNull: false
},
}, {
hooks: {
beforeCount(options) {
options.raw = true;
}
}
});

logs.associate = function (models) {
};

return logs;
};

最佳答案

最后放弃将日志存储在 mysql db 中,因为 mysql 传输包似乎有点过时了。
相反,我使用 winston-daily-rotate-file 在本地存储日志
它可以设置旋转频率,文件的最大大小等。
链接:https://github.com/winstonjs/winston-daily-rotate-file

关于mysql - 如何在 Node.js 中使用 express-winston 将日志存储到 mysql db,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/67086542/

41 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com