From a8c23d90a1c584b54df554c93d8fe5f099db0c4a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E7=8E=8B=E8=89=AF?= <841369634@qq.com> Date: Fri, 10 Jan 2025 13:38:36 +0800 Subject: [PATCH] =?UTF-8?q?feature:=20=E6=97=A5=E5=BF=97=E4=BC=98=E5=8C=96?= =?UTF-8?q?=201=EF=BC=89=E5=90=AF=E7=94=A8=E6=97=A5=E5=BF=97=E5=8E=8B?= =?UTF-8?q?=E7=BC=A9=EF=BC=9B2=EF=BC=89=E6=97=A5=E5=BF=97=E4=BF=9D?= =?UTF-8?q?=E7=95=99=E6=95=B0=E5=92=8C=E4=BF=9D=E5=AD=98=E8=B7=AF=E5=BE=84?= =?UTF-8?q?=E5=8F=AF=E9=85=8D=E7=BD=AE=E5=8C=96=E3=80=82?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- packages/core/src/config/index.js | 4 +++ packages/core/src/utils/util.log.js | 1 + packages/core/src/utils/util.logger.js | 39 ++++++++++++++++++++----- packages/gui/src/view/pages/setting.vue | 7 +++++ 4 files changed, 44 insertions(+), 7 deletions(-) diff --git a/packages/core/src/config/index.js b/packages/core/src/config/index.js index 37468dd..59ae39b 100644 --- a/packages/core/src/config/index.js +++ b/packages/core/src/config/index.js @@ -69,6 +69,10 @@ module.exports = { // 慢速IP延迟时间:测速超过该值时,则视为延迟高,显示为橙色 lowSpeedDelay: 200, + + // 日志相关配置 + logFileSavePath: path.join(getUserBasePath(), '/logs'), // 日志文件保存路径 + keepLogFileCount: 15, // 保留日志文件数 }, compatible: { // **** 自定义兼容配置 **** // diff --git a/packages/core/src/utils/util.log.js b/packages/core/src/utils/util.log.js index 20e1078..5c73495 100644 --- a/packages/core/src/utils/util.log.js +++ b/packages/core/src/utils/util.log.js @@ -1,4 +1,5 @@ const log4js = require('./util.logger') const logger = log4js.getLogger('core') + module.exports = logger diff --git a/packages/core/src/utils/util.logger.js b/packages/core/src/utils/util.logger.js index 6d15c06..275739b 100644 --- a/packages/core/src/utils/util.logger.js +++ b/packages/core/src/utils/util.logger.js @@ -5,19 +5,44 @@ const config = require('../config/index') const level = process.env.NODE_ENV === 'development' ? 'debug' : 'info' function getDefaultConfigBasePath () { - return config.server.setting.userBasePath + if (config.server.setting.logFileSavePath) { + let logFileSavePath = config.server.setting.logFileSavePath + if (logFileSavePath.endsWith('/') || logFileSavePath.endsWith('\\')) { + logFileSavePath = logFileSavePath.slice(0, -1) + } + // eslint-disable-next-line no-template-curly-in-string + return logFileSavePath.replace('${userBasePath}', config.server.setting.userBasePath) + } else { + return path.join(config.server.setting.userBasePath, '/logs') + } } -const coreLogFilename = path.join(getDefaultConfigBasePath(), '/logs/core.log') -const guiLogFilename = path.join(getDefaultConfigBasePath(), '/logs/gui.log') -const serverLogFilename = path.join(getDefaultConfigBasePath(), '/logs/server.log') +// 日志文件名 +const coreLogFilename = path.join(getDefaultConfigBasePath(), '/core.log') +const guiLogFilename = path.join(getDefaultConfigBasePath(), '/gui.log') +const serverLogFilename = path.join(getDefaultConfigBasePath(), '/server.log') +// 日志相关配置 +const backups = config.server.setting.keepLogFileCount // 保留日志文件数 +const appenderConfig = { + type: 'file', + pattern: 'yyyy-MM-dd', + keepFileExt: true, // 保留日志文件扩展名 + compress: true, // 压缩日志文件 + + // 以下三个配置都设置,兼容新旧版本 + backups, + numBackups: backups, + daysToKeep: backups, +} + +// 设置日志配置 log4js.configure({ appenders: { std: { type: 'stdout' }, - core: { type: 'file', pattern: 'yyyy-MM-dd', daysToKeep: 3, filename: coreLogFilename }, - gui: { type: 'file', pattern: 'yyyy-MM-dd', daysToKeep: 3, filename: guiLogFilename }, - server: { level: 'debug', type: 'file', pattern: 'yyyy-MM-dd', daysToKeep: 3, filename: serverLogFilename }, + core: { ...appenderConfig, filename: coreLogFilename }, + gui: { ...appenderConfig, filename: guiLogFilename }, + server: { ...appenderConfig, filename: serverLogFilename }, }, categories: { default: { appenders: ['std'], level }, diff --git a/packages/gui/src/view/pages/setting.vue b/packages/gui/src/view/pages/setting.vue index 6cdc518..0942ab1 100644 --- a/packages/gui/src/view/pages/setting.vue +++ b/packages/gui/src/view/pages/setting.vue @@ -450,6 +450,13 @@ export default { 预发布版本号为带有 “-” 的版本。注:该配置只对当前版本为正式版本时有效。 +
+ + + + + +