From 1448548d31d148608590d4cef54ba0183054bd20 Mon Sep 17 00:00:00 2001 From: Atsushin Date: Tue, 10 Aug 2021 15:25:08 +0900 Subject: [PATCH] BE-880 Fix incorrect multi-process logging (#260) * BE-880 Fix incorrect multi-process logging Signed-off-by: Atsushi Neki * BE-880 Add some comments for implementaion Signed-off-by: Atsushi Neki --- .eslintrc.json | 4 +- app/common/commonUtils.ts | 25 ------- app/common/helper.ts | 91 +++++++++++++++--------- app/sync/listener/ForkListenerHandler.ts | 8 ++- 4 files changed, 67 insertions(+), 61 deletions(-) delete mode 100644 app/common/commonUtils.ts diff --git a/.eslintrc.json b/.eslintrc.json index ac4441146..8a84cb14b 100644 --- a/.eslintrc.json +++ b/.eslintrc.json @@ -398,7 +398,9 @@ "sqlcharacter", "peerlist", "www", - "craetedat" + "craetedat", + "tcp", + "appender" ], "skipWordIfMatch": [ "^\\d+px", diff --git a/app/common/commonUtils.ts b/app/common/commonUtils.ts deleted file mode 100644 index 140ba26ab..000000000 --- a/app/common/commonUtils.ts +++ /dev/null @@ -1,25 +0,0 @@ -/* - * SPDX-License-Identifier: Apache-2.0 - */ - -import { helper } from './helper'; - -const logger = helper.getLogger('ForkSenderHandler'); - -/** - * Returns the number of milliseconds between midnight, - * January 1, 1970 Universal Coordinated Time (UTC) (or GMT) and the specified date. - * - * @param {*} dateStr - * @returns - */ - -export function toUTCmilliseconds(dateStr: any) { - let startSyncMills = null; - try { - startSyncMills = Date.parse(dateStr); - } catch (err) { - logger.error('Unparsable date format, dateStr= ', dateStr, ' ', err); - } - return startSyncMills; -} diff --git a/app/common/helper.ts b/app/common/helper.ts index 2ef502758..e6aa469cf 100644 --- a/app/common/helper.ts +++ b/app/common/helper.ts @@ -68,45 +68,68 @@ export class helper { consoleLevel = process.env.LOG_LEVEL_CONSOLE; } - const logConfig = { - appenders: { - app: { - type: 'dateFile', - filename: appLog, - maxLogSize: 8 * 1024 * 1024, - daysToKeep: 7 + let logConfig: any = {}; + if (!yn(process.env.FORK)) { + logConfig = { + appenders: { + app: { + type: 'dateFile', + filename: appLog, + maxLogSize: 8 * 1024 * 1024, + daysToKeep: 7 + }, + db: { + type: 'dateFile', + filename: dbLog, + maxLogSize: 8 * 1024 * 1024, + daysToKeep: 7 + }, + console: { + type: 'dateFile', + filename: consoleLog, + maxLogSize: 8 * 1024 * 1024, + daysToKeep: 7 + }, + consoleFilter: { + type: 'logLevelFilter', + appender: 'console', + level: consoleLevel + } }, - db: { - type: 'dateFile', - filename: dbLog, - maxLogSize: 8 * 1024 * 1024, - daysToKeep: 7 - }, - console: { - type: 'dateFile', - filename: consoleLog, - maxLogSize: 8 * 1024 * 1024, - daysToKeep: 7 - }, - consoleFilter: { - type: 'logLevelFilter', - appender: 'console', - level: consoleLevel + categories: { + default: { appenders: ['consoleFilter', 'app'], level: appLevel }, + PgService: { appenders: ['consoleFilter', 'db'], level: dbLevel } } - }, - categories: { - default: { appenders: ['consoleFilter', 'app'], level: appLevel }, - PgService: { appenders: ['consoleFilter', 'db'], level: dbLevel } - } - }; + }; - if (process.env.LOG_CONSOLE_STDOUT) { - if (yn(process.env.LOG_CONSOLE_STDOUT)) { - logConfig.appenders.console = { - ...logConfig.appenders.console, - type: 'console' + if (moduleName === 'main') { + // Should initiate logger once with tcp-server appender + logConfig.appenders = { + ...logConfig.appenders, + server: { type: 'tcp-server' } }; } + + if (process.env.LOG_CONSOLE_STDOUT) { + if (yn(process.env.LOG_CONSOLE_STDOUT)) { + logConfig.appenders.console = { + ...logConfig.appenders.console, + type: 'console' + }; + } + } + } else { + logConfig = { + appenders: { + network: { + type: 'tcp' + } + }, + categories: { + default: { appenders: ['network'], level: appLevel }, + PgService: { appenders: ['network'], level: dbLevel } + } + }; } log4js.configure(logConfig); diff --git a/app/sync/listener/ForkListenerHandler.ts b/app/sync/listener/ForkListenerHandler.ts index 111115882..3632f734e 100644 --- a/app/sync/listener/ForkListenerHandler.ts +++ b/app/sync/listener/ForkListenerHandler.ts @@ -31,7 +31,13 @@ export class ForkListenerHandler { * @memberof ForkListenerHandler */ async initialize(args) { - this.syncProcessor = fork(path.resolve(__dirname, '../../sync.js'), args); + this.syncProcessor = fork(path.resolve(__dirname, '../../sync.js'), args, { + env: { + ...process.env, + // Mark forked process explicitly for logging using TCP server + FORK: '1' + } + }); this.syncProcessor.on('message', msg => { this.platform.getProxy().processSyncMessage(msg);