crewly 1.0.3 → 1.0.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/config/roles/orchestrator/prompt.md +61 -2
- package/config/skills/orchestrator/remember/instructions.md +8 -1
- package/config/skills/orchestrator/update-team/execute.sh +16 -0
- package/config/skills/orchestrator/update-team/instructions.md +21 -0
- package/config/skills/orchestrator/update-team/skill.json +20 -0
- package/dist/backend/backend/src/controllers/messaging/delivery-logs.controller.d.ts.map +1 -1
- package/dist/backend/backend/src/controllers/messaging/delivery-logs.controller.js +4 -2
- package/dist/backend/backend/src/controllers/messaging/delivery-logs.controller.js.map +1 -1
- package/dist/backend/backend/src/controllers/messaging/scheduled-messages.controller.d.ts.map +1 -1
- package/dist/backend/backend/src/controllers/messaging/scheduled-messages.controller.js +10 -8
- package/dist/backend/backend/src/controllers/messaging/scheduled-messages.controller.js.map +1 -1
- package/dist/backend/backend/src/controllers/orchestrator/orchestrator.controller.d.ts.map +1 -1
- package/dist/backend/backend/src/controllers/orchestrator/orchestrator.controller.js +28 -26
- package/dist/backend/backend/src/controllers/orchestrator/orchestrator.controller.js.map +1 -1
- package/dist/backend/backend/src/controllers/project/git.controller.d.ts.map +1 -1
- package/dist/backend/backend/src/controllers/project/git.controller.js +9 -7
- package/dist/backend/backend/src/controllers/project/git.controller.js.map +1 -1
- package/dist/backend/backend/src/controllers/project/project.controller.d.ts.map +1 -1
- package/dist/backend/backend/src/controllers/project/project.controller.js +52 -50
- package/dist/backend/backend/src/controllers/project/project.controller.js.map +1 -1
- package/dist/backend/backend/src/controllers/skill/skill.controller.d.ts.map +1 -1
- package/dist/backend/backend/src/controllers/skill/skill.controller.js +3 -1
- package/dist/backend/backend/src/controllers/skill/skill.controller.js.map +1 -1
- package/dist/backend/backend/src/controllers/slack/slack-thread.controller.d.ts.map +1 -1
- package/dist/backend/backend/src/controllers/slack/slack-thread.controller.js +3 -1
- package/dist/backend/backend/src/controllers/slack/slack-thread.controller.js.map +1 -1
- package/dist/backend/backend/src/controllers/system/config.controller.d.ts.map +1 -1
- package/dist/backend/backend/src/controllers/system/config.controller.js +3 -1
- package/dist/backend/backend/src/controllers/system/config.controller.js.map +1 -1
- package/dist/backend/backend/src/controllers/system/errors.controller.d.ts.map +1 -1
- package/dist/backend/backend/src/controllers/system/errors.controller.js +7 -5
- package/dist/backend/backend/src/controllers/system/errors.controller.js.map +1 -1
- package/dist/backend/backend/src/controllers/system/scheduler.controller.d.ts.map +1 -1
- package/dist/backend/backend/src/controllers/system/scheduler.controller.js +6 -4
- package/dist/backend/backend/src/controllers/system/scheduler.controller.js.map +1 -1
- package/dist/backend/backend/src/controllers/system/system.controller.d.ts.map +1 -1
- package/dist/backend/backend/src/controllers/system/system.controller.js +20 -19
- package/dist/backend/backend/src/controllers/system/system.controller.js.map +1 -1
- package/dist/backend/backend/src/controllers/task-management/assignments.controller.d.ts.map +1 -1
- package/dist/backend/backend/src/controllers/task-management/assignments.controller.js +4 -2
- package/dist/backend/backend/src/controllers/task-management/assignments.controller.js.map +1 -1
- package/dist/backend/backend/src/controllers/task-management/in-progress-tasks.controller.d.ts.map +1 -1
- package/dist/backend/backend/src/controllers/task-management/in-progress-tasks.controller.js +3 -1
- package/dist/backend/backend/src/controllers/task-management/in-progress-tasks.controller.js.map +1 -1
- package/dist/backend/backend/src/controllers/task-management/task-management.controller.d.ts.map +1 -1
- package/dist/backend/backend/src/controllers/task-management/task-management.controller.js +30 -28
- package/dist/backend/backend/src/controllers/task-management/task-management.controller.js.map +1 -1
- package/dist/backend/backend/src/controllers/task-management/tasks.controller.d.ts.map +1 -1
- package/dist/backend/backend/src/controllers/task-management/tasks.controller.js +7 -5
- package/dist/backend/backend/src/controllers/task-management/tasks.controller.js.map +1 -1
- package/dist/backend/backend/src/controllers/task-management/tickets.controller.d.ts.map +1 -1
- package/dist/backend/backend/src/controllers/task-management/tickets.controller.js +12 -10
- package/dist/backend/backend/src/controllers/task-management/tickets.controller.js.map +1 -1
- package/dist/backend/backend/src/controllers/team/team.controller.d.ts.map +1 -1
- package/dist/backend/backend/src/controllers/team/team.controller.js +44 -42
- package/dist/backend/backend/src/controllers/team/team.controller.js.map +1 -1
- package/dist/backend/backend/src/controllers/team/team.routes.d.ts.map +1 -1
- package/dist/backend/backend/src/controllers/team/team.routes.js +1 -0
- package/dist/backend/backend/src/controllers/team/team.routes.js.map +1 -1
- package/dist/backend/backend/src/index.d.ts.map +1 -1
- package/dist/backend/backend/src/index.js +5 -1
- package/dist/backend/backend/src/index.js.map +1 -1
- package/dist/backend/backend/src/routes/factory.routes.d.ts.map +1 -1
- package/dist/backend/backend/src/routes/factory.routes.js +4 -2
- package/dist/backend/backend/src/routes/factory.routes.js.map +1 -1
- package/dist/backend/backend/src/services/agent/agent-heartbeat-monitor.service.d.ts.map +1 -1
- package/dist/backend/backend/src/services/agent/agent-heartbeat-monitor.service.js +8 -2
- package/dist/backend/backend/src/services/agent/agent-heartbeat-monitor.service.js.map +1 -1
- package/dist/backend/backend/src/services/agent/agent-registration.service.d.ts +6 -0
- package/dist/backend/backend/src/services/agent/agent-registration.service.d.ts.map +1 -1
- package/dist/backend/backend/src/services/agent/agent-registration.service.js +29 -6
- package/dist/backend/backend/src/services/agent/agent-registration.service.js.map +1 -1
- package/dist/backend/backend/src/services/agent/runtime-agent.service.abstract.d.ts.map +1 -1
- package/dist/backend/backend/src/services/agent/runtime-agent.service.abstract.js +22 -8
- package/dist/backend/backend/src/services/agent/runtime-agent.service.abstract.js.map +1 -1
- package/dist/backend/backend/src/services/agent/runtime-exit-monitor.service.d.ts.map +1 -1
- package/dist/backend/backend/src/services/agent/runtime-exit-monitor.service.js +9 -3
- package/dist/backend/backend/src/services/agent/runtime-exit-monitor.service.js.map +1 -1
- package/dist/backend/backend/src/services/ai/context-loader.service.d.ts +1 -0
- package/dist/backend/backend/src/services/ai/context-loader.service.d.ts.map +1 -1
- package/dist/backend/backend/src/services/ai/context-loader.service.js +9 -7
- package/dist/backend/backend/src/services/ai/context-loader.service.js.map +1 -1
- package/dist/backend/backend/src/services/ai/prompt-template.service.d.ts +1 -0
- package/dist/backend/backend/src/services/ai/prompt-template.service.d.ts.map +1 -1
- package/dist/backend/backend/src/services/ai/prompt-template.service.js +7 -5
- package/dist/backend/backend/src/services/ai/prompt-template.service.js.map +1 -1
- package/dist/backend/backend/src/services/core/config.service.d.ts +6 -0
- package/dist/backend/backend/src/services/core/config.service.d.ts.map +1 -1
- package/dist/backend/backend/src/services/core/config.service.js +25 -5
- package/dist/backend/backend/src/services/core/config.service.js.map +1 -1
- package/dist/backend/backend/src/services/core/storage.service.d.ts +10 -2
- package/dist/backend/backend/src/services/core/storage.service.d.ts.map +1 -1
- package/dist/backend/backend/src/services/core/storage.service.js +45 -29
- package/dist/backend/backend/src/services/core/storage.service.js.map +1 -1
- package/dist/backend/backend/src/services/monitoring/activity-monitor.service.d.ts.map +1 -1
- package/dist/backend/backend/src/services/monitoring/activity-monitor.service.js +50 -33
- package/dist/backend/backend/src/services/monitoring/activity-monitor.service.js.map +1 -1
- package/dist/backend/backend/src/services/monitoring/team-activity-websocket.service.d.ts +4 -1
- package/dist/backend/backend/src/services/monitoring/team-activity-websocket.service.d.ts.map +1 -1
- package/dist/backend/backend/src/services/monitoring/team-activity-websocket.service.js +28 -14
- package/dist/backend/backend/src/services/monitoring/team-activity-websocket.service.js.map +1 -1
- package/dist/backend/backend/src/services/orchestrator/improvement-startup.service.d.ts +1 -0
- package/dist/backend/backend/src/services/orchestrator/improvement-startup.service.d.ts.map +1 -1
- package/dist/backend/backend/src/services/orchestrator/improvement-startup.service.js +22 -20
- package/dist/backend/backend/src/services/orchestrator/improvement-startup.service.js.map +1 -1
- package/dist/backend/backend/src/services/orchestrator/orchestrator-heartbeat-monitor.service.d.ts.map +1 -1
- package/dist/backend/backend/src/services/orchestrator/orchestrator-heartbeat-monitor.service.js +11 -2
- package/dist/backend/backend/src/services/orchestrator/orchestrator-heartbeat-monitor.service.js.map +1 -1
- package/dist/backend/backend/src/services/orchestrator/safe-restart.service.d.ts +1 -0
- package/dist/backend/backend/src/services/orchestrator/safe-restart.service.d.ts.map +1 -1
- package/dist/backend/backend/src/services/orchestrator/safe-restart.service.js +25 -23
- package/dist/backend/backend/src/services/orchestrator/safe-restart.service.js.map +1 -1
- package/dist/backend/backend/src/services/orchestrator/self-improvement.service.d.ts +1 -0
- package/dist/backend/backend/src/services/orchestrator/self-improvement.service.d.ts.map +1 -1
- package/dist/backend/backend/src/services/orchestrator/self-improvement.service.js +12 -10
- package/dist/backend/backend/src/services/orchestrator/self-improvement.service.js.map +1 -1
- package/dist/backend/backend/src/services/orchestrator/slack-bridge-lazy.d.ts +17 -0
- package/dist/backend/backend/src/services/orchestrator/slack-bridge-lazy.d.ts.map +1 -0
- package/dist/backend/backend/src/services/orchestrator/slack-bridge-lazy.js +30 -0
- package/dist/backend/backend/src/services/orchestrator/slack-bridge-lazy.js.map +1 -0
- package/dist/backend/backend/src/services/orchestrator/state-persistence.service.d.ts +1 -0
- package/dist/backend/backend/src/services/orchestrator/state-persistence.service.d.ts.map +1 -1
- package/dist/backend/backend/src/services/orchestrator/state-persistence.service.js +14 -12
- package/dist/backend/backend/src/services/orchestrator/state-persistence.service.js.map +1 -1
- package/dist/backend/backend/src/services/project/active-projects.service.d.ts +1 -0
- package/dist/backend/backend/src/services/project/active-projects.service.d.ts.map +1 -1
- package/dist/backend/backend/src/services/project/active-projects.service.js +8 -6
- package/dist/backend/backend/src/services/project/active-projects.service.js.map +1 -1
- package/dist/backend/backend/src/services/project/task-tracking.service.d.ts +1 -0
- package/dist/backend/backend/src/services/project/task-tracking.service.d.ts.map +1 -1
- package/dist/backend/backend/src/services/project/task-tracking.service.js +18 -16
- package/dist/backend/backend/src/services/project/task-tracking.service.js.map +1 -1
- package/dist/backend/backend/src/services/project/ticket-editor.service.d.ts +1 -0
- package/dist/backend/backend/src/services/project/ticket-editor.service.d.ts.map +1 -1
- package/dist/backend/backend/src/services/project/ticket-editor.service.js +6 -4
- package/dist/backend/backend/src/services/project/ticket-editor.service.js.map +1 -1
- package/dist/backend/backend/src/services/settings/role.service.d.ts +1 -0
- package/dist/backend/backend/src/services/settings/role.service.d.ts.map +1 -1
- package/dist/backend/backend/src/services/settings/role.service.js +3 -1
- package/dist/backend/backend/src/services/settings/role.service.js.map +1 -1
- package/dist/backend/backend/src/services/skill/skill-executor.service.d.ts +1 -0
- package/dist/backend/backend/src/services/skill/skill-executor.service.d.ts.map +1 -1
- package/dist/backend/backend/src/services/skill/skill-executor.service.js +4 -2
- package/dist/backend/backend/src/services/skill/skill-executor.service.js.map +1 -1
- package/dist/backend/backend/src/services/skill/skill.service.d.ts +1 -0
- package/dist/backend/backend/src/services/skill/skill.service.d.ts.map +1 -1
- package/dist/backend/backend/src/services/skill/skill.service.js +7 -5
- package/dist/backend/backend/src/services/skill/skill.service.js.map +1 -1
- package/dist/backend/backend/src/services/slack/slack-image.service.d.ts +1 -0
- package/dist/backend/backend/src/services/slack/slack-image.service.d.ts.map +1 -1
- package/dist/backend/backend/src/services/slack/slack-image.service.js +6 -4
- package/dist/backend/backend/src/services/slack/slack-image.service.js.map +1 -1
- package/dist/backend/backend/src/services/slack/slack-initializer.d.ts.map +1 -1
- package/dist/backend/backend/src/services/slack/slack-initializer.js +7 -5
- package/dist/backend/backend/src/services/slack/slack-initializer.js.map +1 -1
- package/dist/backend/backend/src/services/slack/slack-orchestrator-bridge.d.ts +1 -0
- package/dist/backend/backend/src/services/slack/slack-orchestrator-bridge.d.ts.map +1 -1
- package/dist/backend/backend/src/services/slack/slack-orchestrator-bridge.js +25 -20
- package/dist/backend/backend/src/services/slack/slack-orchestrator-bridge.js.map +1 -1
- package/dist/backend/backend/src/services/slack/slack.service.d.ts +1 -0
- package/dist/backend/backend/src/services/slack/slack.service.d.ts.map +1 -1
- package/dist/backend/backend/src/services/slack/slack.service.js +19 -15
- package/dist/backend/backend/src/services/slack/slack.service.js.map +1 -1
- package/dist/backend/backend/src/utils/process-recovery.d.ts +1 -0
- package/dist/backend/backend/src/utils/process-recovery.d.ts.map +1 -1
- package/dist/backend/backend/src/utils/process-recovery.js +40 -37
- package/dist/backend/backend/src/utils/process-recovery.js.map +1 -1
- package/dist/backend/backend/src/utils/prompt-resolver.d.ts.map +1 -1
- package/dist/backend/backend/src/utils/prompt-resolver.js +3 -1
- package/dist/backend/backend/src/utils/prompt-resolver.js.map +1 -1
- package/dist/backend/backend/src/utils/resource-monitor.d.ts +2 -1
- package/dist/backend/backend/src/utils/resource-monitor.d.ts.map +1 -1
- package/dist/backend/backend/src/utils/resource-monitor.js +34 -24
- package/dist/backend/backend/src/utils/resource-monitor.js.map +1 -1
- package/dist/cli/cli/src/commands/onboard.d.ts +89 -0
- package/dist/cli/cli/src/commands/onboard.d.ts.map +1 -0
- package/dist/cli/cli/src/commands/onboard.js +268 -0
- package/dist/cli/cli/src/commands/onboard.js.map +1 -0
- package/dist/cli/cli/src/index.js +5 -0
- package/dist/cli/cli/src/index.js.map +1 -1
- package/dist/cli/cli/src/utils/marketplace.d.ts +22 -0
- package/dist/cli/cli/src/utils/marketplace.d.ts.map +1 -1
- package/dist/cli/cli/src/utils/marketplace.js +43 -0
- package/dist/cli/cli/src/utils/marketplace.js.map +1 -1
- package/frontend/dist/assets/{index-4c56763b.js → index-419da091.js} +2 -2
- package/frontend/dist/assets/index-5adb4dff.css +33 -0
- package/frontend/dist/index.html +2 -2
- package/package.json +2 -1
- package/frontend/dist/assets/index-c1dd0b10.css +0 -33
|
@@ -2,6 +2,7 @@
|
|
|
2
2
|
import { spawn } from 'child_process';
|
|
3
3
|
import { EventEmitter } from 'events';
|
|
4
4
|
import path from 'path';
|
|
5
|
+
import { LoggerService } from '../services/core/logger.service.js';
|
|
5
6
|
/**
|
|
6
7
|
* ProcessRecovery manages automatic restart and monitoring of the Crewly backend process
|
|
7
8
|
*
|
|
@@ -29,8 +30,10 @@ export class ProcessRecovery extends EventEmitter {
|
|
|
29
30
|
memoryMonitorInterval = null;
|
|
30
31
|
processStartTime = 0;
|
|
31
32
|
minRuntime = 30000; // Process must run for at least 30 seconds
|
|
33
|
+
logger;
|
|
32
34
|
constructor() {
|
|
33
35
|
super();
|
|
36
|
+
this.logger = LoggerService.getInstance().createComponentLogger('ProcessRecovery');
|
|
34
37
|
this.setupSignalHandlers();
|
|
35
38
|
}
|
|
36
39
|
/**
|
|
@@ -39,9 +42,8 @@ export class ProcessRecovery extends EventEmitter {
|
|
|
39
42
|
* @returns Promise that resolves when the process recovery system is started
|
|
40
43
|
*/
|
|
41
44
|
async start() {
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
console.log(`⏱️ Min runtime: ${this.minRuntime / 1000}s`);
|
|
45
|
+
this.logger.info('Starting Crewly Backend with Process Recovery');
|
|
46
|
+
this.logger.info('Recovery configuration', { maxRestarts: this.maxRestarts, minRuntimeSeconds: this.minRuntime / 1000 });
|
|
45
47
|
await this.startBackendProcess();
|
|
46
48
|
this.startHealthChecks();
|
|
47
49
|
this.startMemoryMonitoring();
|
|
@@ -53,12 +55,15 @@ export class ProcessRecovery extends EventEmitter {
|
|
|
53
55
|
*/
|
|
54
56
|
async startBackendProcess() {
|
|
55
57
|
if (this.isShuttingDown) {
|
|
56
|
-
|
|
58
|
+
this.logger.info('Shutdown in progress, not starting process');
|
|
57
59
|
return;
|
|
58
60
|
}
|
|
59
61
|
const backendScript = path.resolve(process.cwd(), 'backend/src/index.js');
|
|
60
|
-
|
|
61
|
-
|
|
62
|
+
this.logger.info('Starting backend process', {
|
|
63
|
+
attempt: this.restartCount + 1,
|
|
64
|
+
maxAttempts: this.maxRestarts + 1,
|
|
65
|
+
script: backendScript,
|
|
66
|
+
});
|
|
62
67
|
this.processStartTime = Date.now();
|
|
63
68
|
this.childProcess = spawn('node', [backendScript], {
|
|
64
69
|
stdio: ['pipe', 'pipe', 'pipe'],
|
|
@@ -72,25 +77,25 @@ export class ProcessRecovery extends EventEmitter {
|
|
|
72
77
|
if (!this.childProcess.pid) {
|
|
73
78
|
throw new Error('Failed to start backend process');
|
|
74
79
|
}
|
|
75
|
-
|
|
80
|
+
this.logger.info('Backend process started', { pid: this.childProcess.pid });
|
|
76
81
|
// Handle process output
|
|
77
82
|
this.childProcess.stdout?.on('data', (data) => {
|
|
78
83
|
const output = data.toString().trim();
|
|
79
|
-
|
|
84
|
+
this.logger.info('Backend output', { output });
|
|
80
85
|
// Check for successful startup
|
|
81
86
|
if (output.includes('Crewly server started on port')) {
|
|
82
|
-
|
|
87
|
+
this.logger.info('Backend process started successfully');
|
|
83
88
|
this.emit('process_started');
|
|
84
89
|
}
|
|
85
90
|
// Check for port conflicts
|
|
86
91
|
if (output.includes('EADDRINUSE') || output.includes('already in use')) {
|
|
87
|
-
|
|
92
|
+
this.logger.warn('Port conflict detected');
|
|
88
93
|
this.emit('port_conflict');
|
|
89
94
|
}
|
|
90
95
|
});
|
|
91
96
|
this.childProcess.stderr?.on('data', (data) => {
|
|
92
97
|
const error = data.toString().trim();
|
|
93
|
-
|
|
98
|
+
this.logger.error('Backend error output', { output: error });
|
|
94
99
|
// Track critical errors
|
|
95
100
|
if (error.includes('FATAL') || error.includes('Cannot start')) {
|
|
96
101
|
this.emit('critical_error', error);
|
|
@@ -99,7 +104,7 @@ export class ProcessRecovery extends EventEmitter {
|
|
|
99
104
|
// Handle process exit
|
|
100
105
|
this.childProcess.on('exit', async (code, signal) => {
|
|
101
106
|
const runtime = Date.now() - this.processStartTime;
|
|
102
|
-
|
|
107
|
+
this.logger.info('Backend process exited', { code, signal, runtimeMs: runtime });
|
|
103
108
|
this.childProcess = null;
|
|
104
109
|
this.emit('process_exit', { code, signal, runtime });
|
|
105
110
|
if (!this.isShuttingDown) {
|
|
@@ -107,7 +112,7 @@ export class ProcessRecovery extends EventEmitter {
|
|
|
107
112
|
}
|
|
108
113
|
});
|
|
109
114
|
this.childProcess.on('error', (error) => {
|
|
110
|
-
|
|
115
|
+
this.logger.error('Backend process error', { error: error.message, stack: error.stack });
|
|
111
116
|
this.emit('process_error', error);
|
|
112
117
|
});
|
|
113
118
|
}
|
|
@@ -121,18 +126,18 @@ export class ProcessRecovery extends EventEmitter {
|
|
|
121
126
|
async handleProcessExit(code, signal, runtime) {
|
|
122
127
|
// Don't restart if explicitly killed or shutdown
|
|
123
128
|
if (signal === 'SIGTERM' || signal === 'SIGINT' || code === 0) {
|
|
124
|
-
|
|
129
|
+
this.logger.info('Process exited gracefully, not restarting');
|
|
125
130
|
return;
|
|
126
131
|
}
|
|
127
132
|
// Check if we've exceeded restart limits
|
|
128
133
|
if (this.restartCount >= this.maxRestarts) {
|
|
129
|
-
|
|
134
|
+
this.logger.error('Maximum restart attempts exceeded', { maxRestarts: this.maxRestarts });
|
|
130
135
|
this.emit('max_restarts_exceeded');
|
|
131
136
|
return;
|
|
132
137
|
}
|
|
133
138
|
// If process crashed too quickly, it's likely a persistent issue
|
|
134
139
|
if (runtime < this.minRuntime) {
|
|
135
|
-
|
|
140
|
+
this.logger.warn('Process crashed too quickly', { runtimeMs: runtime, minRuntimeMs: this.minRuntime });
|
|
136
141
|
this.restartCount++;
|
|
137
142
|
}
|
|
138
143
|
else {
|
|
@@ -141,13 +146,13 @@ export class ProcessRecovery extends EventEmitter {
|
|
|
141
146
|
}
|
|
142
147
|
// Calculate retry delay with exponential backoff
|
|
143
148
|
const retryDelay = Math.min(this.baseRetryDelay * Math.pow(2, this.restartCount), this.maxRetryDelay);
|
|
144
|
-
|
|
149
|
+
this.logger.info('Restarting backend process', { retryDelaySeconds: retryDelay / 1000, attempt: this.restartCount + 1 });
|
|
145
150
|
setTimeout(async () => {
|
|
146
151
|
try {
|
|
147
152
|
await this.startBackendProcess();
|
|
148
153
|
}
|
|
149
154
|
catch (error) {
|
|
150
|
-
|
|
155
|
+
this.logger.error('Failed to restart backend process', { error: error instanceof Error ? error.message : String(error) });
|
|
151
156
|
this.restartCount++;
|
|
152
157
|
await this.handleProcessExit(1, null, 0);
|
|
153
158
|
}
|
|
@@ -163,17 +168,12 @@ export class ProcessRecovery extends EventEmitter {
|
|
|
163
168
|
try {
|
|
164
169
|
// Simple health check - verify process is still running
|
|
165
170
|
if (this.childProcess.killed || this.childProcess.exitCode !== null) {
|
|
166
|
-
|
|
171
|
+
this.logger.warn('Health check failed: process is not running');
|
|
167
172
|
return;
|
|
168
173
|
}
|
|
169
|
-
// You could add HTTP health check here
|
|
170
|
-
// const response = await fetch('http://localhost:3000/health');
|
|
171
|
-
// if (!response.ok) {
|
|
172
|
-
// console.warn('⚠️ Health check failed: HTTP endpoint not responding');
|
|
173
|
-
// }
|
|
174
174
|
}
|
|
175
175
|
catch (error) {
|
|
176
|
-
|
|
176
|
+
this.logger.warn('Health check error', { error: error instanceof Error ? error.message : String(error) });
|
|
177
177
|
}
|
|
178
178
|
}, 30000); // Check every 30 seconds
|
|
179
179
|
}
|
|
@@ -186,10 +186,10 @@ export class ProcessRecovery extends EventEmitter {
|
|
|
186
186
|
return;
|
|
187
187
|
const usage = process.memoryUsage();
|
|
188
188
|
const heapUsed = Math.round(usage.heapUsed / 1024 / 1024);
|
|
189
|
-
|
|
189
|
+
this.logger.debug('Recovery process memory', { heapUsedMB: heapUsed });
|
|
190
190
|
// Warn if recovery process itself is using too much memory
|
|
191
191
|
if (heapUsed > 100) {
|
|
192
|
-
|
|
192
|
+
this.logger.warn('Recovery process high memory usage', { heapUsedMB: heapUsed });
|
|
193
193
|
}
|
|
194
194
|
}, 60000); // Check every minute
|
|
195
195
|
}
|
|
@@ -200,11 +200,13 @@ export class ProcessRecovery extends EventEmitter {
|
|
|
200
200
|
process.on('SIGTERM', () => this.shutdown('SIGTERM'));
|
|
201
201
|
process.on('SIGINT', () => this.shutdown('SIGINT'));
|
|
202
202
|
process.on('uncaughtException', (error) => {
|
|
203
|
-
|
|
203
|
+
this.logger.error('Uncaught exception in recovery process', { error: error.message, stack: error.stack });
|
|
204
204
|
this.shutdown('uncaughtException');
|
|
205
205
|
});
|
|
206
206
|
process.on('unhandledRejection', (reason) => {
|
|
207
|
-
|
|
207
|
+
this.logger.error('Unhandled rejection in recovery process', {
|
|
208
|
+
reason: reason instanceof Error ? reason.message : String(reason),
|
|
209
|
+
});
|
|
208
210
|
this.shutdown('unhandledRejection');
|
|
209
211
|
});
|
|
210
212
|
}
|
|
@@ -217,7 +219,7 @@ export class ProcessRecovery extends EventEmitter {
|
|
|
217
219
|
if (this.isShuttingDown)
|
|
218
220
|
return;
|
|
219
221
|
this.isShuttingDown = true;
|
|
220
|
-
|
|
222
|
+
this.logger.info('Shutting down process recovery', { signal });
|
|
221
223
|
// Clear intervals
|
|
222
224
|
if (this.healthCheckInterval) {
|
|
223
225
|
clearInterval(this.healthCheckInterval);
|
|
@@ -227,13 +229,13 @@ export class ProcessRecovery extends EventEmitter {
|
|
|
227
229
|
}
|
|
228
230
|
// Gracefully stop backend process
|
|
229
231
|
if (this.childProcess && !this.childProcess.killed) {
|
|
230
|
-
|
|
232
|
+
this.logger.info('Sending SIGTERM to backend process');
|
|
231
233
|
this.childProcess.kill('SIGTERM');
|
|
232
234
|
// Wait up to 10 seconds for graceful shutdown
|
|
233
235
|
await new Promise((resolve) => {
|
|
234
236
|
const timeout = setTimeout(() => {
|
|
235
237
|
if (this.childProcess && !this.childProcess.killed) {
|
|
236
|
-
|
|
238
|
+
this.logger.info('Force killing backend process');
|
|
237
239
|
this.childProcess.kill('SIGKILL');
|
|
238
240
|
}
|
|
239
241
|
resolve();
|
|
@@ -244,7 +246,7 @@ export class ProcessRecovery extends EventEmitter {
|
|
|
244
246
|
});
|
|
245
247
|
});
|
|
246
248
|
}
|
|
247
|
-
|
|
249
|
+
this.logger.info('Process recovery shutdown complete');
|
|
248
250
|
process.exit(0);
|
|
249
251
|
}
|
|
250
252
|
/**
|
|
@@ -264,19 +266,20 @@ export class ProcessRecovery extends EventEmitter {
|
|
|
264
266
|
// If this script is run directly, start the recovery system
|
|
265
267
|
const _isMain = process.argv[1]?.endsWith('process-recovery.ts') || process.argv[1]?.endsWith('process-recovery.js');
|
|
266
268
|
if (_isMain) {
|
|
269
|
+
const logger = LoggerService.getInstance().createComponentLogger('ProcessRecovery');
|
|
267
270
|
const recovery = new ProcessRecovery();
|
|
268
271
|
recovery.on('process_started', () => {
|
|
269
|
-
|
|
272
|
+
logger.info('Backend process started successfully');
|
|
270
273
|
});
|
|
271
274
|
recovery.on('process_exit', ({ code, signal, runtime }) => {
|
|
272
|
-
|
|
275
|
+
logger.info('Process exit', { code, signal, runtimeMs: runtime });
|
|
273
276
|
});
|
|
274
277
|
recovery.on('max_restarts_exceeded', () => {
|
|
275
|
-
|
|
278
|
+
logger.error('Maximum restart attempts exceeded, exiting');
|
|
276
279
|
process.exit(1);
|
|
277
280
|
});
|
|
278
281
|
recovery.start().catch((error) => {
|
|
279
|
-
|
|
282
|
+
logger.error('Failed to start process recovery', { error: error instanceof Error ? error.message : String(error) });
|
|
280
283
|
process.exit(1);
|
|
281
284
|
});
|
|
282
285
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"process-recovery.js","sourceRoot":"","sources":["../../../../../backend/src/utils/process-recovery.ts"],"names":[],"mappings":";AAEA,OAAO,EAAE,KAAK,EAAgB,MAAM,eAAe,CAAC;AACpD,OAAO,EAAE,YAAY,EAAE,MAAM,QAAQ,CAAC;AACtC,OAAO,IAAI,MAAM,MAAM,CAAC;
|
|
1
|
+
{"version":3,"file":"process-recovery.js","sourceRoot":"","sources":["../../../../../backend/src/utils/process-recovery.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"prompt-resolver.d.ts","sourceRoot":"","sources":["../../../../../backend/src/utils/prompt-resolver.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"prompt-resolver.d.ts","sourceRoot":"","sources":["../../../../../backend/src/utils/prompt-resolver.ts"],"names":[],"mappings":"AAOA;;GAEG;AACH,MAAM,WAAW,UAAU;IACzB,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,UAAU,EAAE,MAAM,CAAC;IACnB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,YAAY,CAAC,EAAE,GAAG,CAAC;IACnB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,OAAO,CAAC,EAAE,MAAM,EAAE,CAAC;CACpB;AAED;;;;;;;;;;;;GAYG;AACH,wBAAsB,kBAAkB,CACtC,IAAI,EAAE,UAAU,EAChB,WAAW,GAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAM,GACvC,OAAO,CAAC,MAAM,EAAE,CAAC,CAiCnB;AAkBD;;;;;;;;;;;;;;;GAeG;AACH,wBAAgB,wBAAwB,CAAC,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,GAAG,MAAM,CAU7F;AAED;;;;;;;GAOG;AACH,wBAAsB,iBAAiB,CACrC,IAAI,EAAE,UAAU,EAChB,WAAW,GAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAM,GACvC,OAAO,CAAC,UAAU,GAAG;IAAE,OAAO,EAAE,MAAM,EAAE,CAAA;CAAE,CAAC,CAO7C;AAED;;;;;;GAMG;AACH,wBAAsB,oBAAoB,CACxC,KAAK,EAAE,UAAU,EAAE,EACnB,WAAW,GAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAM,GACvC,OAAO,CAAC,KAAK,CAAC,UAAU,GAAG;IAAE,OAAO,EAAE,MAAM,EAAE,CAAA;CAAE,CAAC,CAAC,CAMpD;AAED;;;;;;GAMG;AACH,wBAAsB,oBAAoB,CACxC,UAAU,EAAE,MAAM,EAClB,WAAW,GAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAM,GACvC,OAAO,CAAC;IAAE,KAAK,EAAE,KAAK,CAAC,UAAU,GAAG;QAAE,OAAO,EAAE,MAAM,EAAE,CAAA;KAAE,CAAC,CAAC;IAAC,CAAC,GAAG,EAAE,MAAM,GAAG,GAAG,CAAA;CAAE,CAAC,CAmBnF"}
|
|
@@ -1,6 +1,8 @@
|
|
|
1
1
|
import { readFile } from 'fs/promises';
|
|
2
2
|
import { resolve } from 'path';
|
|
3
3
|
import { existsSync } from 'fs';
|
|
4
|
+
import { LoggerService } from '../services/core/logger.service.js';
|
|
5
|
+
const logger = LoggerService.getInstance().createComponentLogger('PromptResolver');
|
|
4
6
|
/**
|
|
5
7
|
* Loads and processes prompt content from markdown files or inline arrays
|
|
6
8
|
*
|
|
@@ -39,7 +41,7 @@ export async function resolveStepPrompts(step, projectVars = {}) {
|
|
|
39
41
|
return step.prompts.map(prompt => replaceTemplateVariables(prompt, projectVars));
|
|
40
42
|
}
|
|
41
43
|
// If neither prompt_file nor prompts are available, return empty array
|
|
42
|
-
|
|
44
|
+
logger.warn('Step has no prompt_file or prompts array', { stepId: step.id, stepName: step.name });
|
|
43
45
|
return [];
|
|
44
46
|
}
|
|
45
47
|
/**
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"prompt-resolver.js","sourceRoot":"","sources":["../../../../../backend/src/utils/prompt-resolver.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AACvC,OAAO,EAAQ,OAAO,EAAE,MAAM,MAAM,CAAC;AACrC,OAAO,EAAE,UAAU,EAAE,MAAM,IAAI,CAAC;
|
|
1
|
+
{"version":3,"file":"prompt-resolver.js","sourceRoot":"","sources":["../../../../../backend/src/utils/prompt-resolver.ts"],"names":[],"mappings":"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"}
|
|
@@ -56,7 +56,7 @@ interface ResourceMetrics {
|
|
|
56
56
|
* });
|
|
57
57
|
*
|
|
58
58
|
* monitor.on('warning', (metrics) => {
|
|
59
|
-
*
|
|
59
|
+
* // Handle resource warning
|
|
60
60
|
* });
|
|
61
61
|
*
|
|
62
62
|
* monitor.start();
|
|
@@ -71,6 +71,7 @@ export declare class ResourceMonitor extends EventEmitter {
|
|
|
71
71
|
private memoryHistory;
|
|
72
72
|
private cpuHistory;
|
|
73
73
|
private isMonitoring;
|
|
74
|
+
private logger;
|
|
74
75
|
private readonly DEFAULT_THRESHOLDS;
|
|
75
76
|
constructor(thresholds?: Partial<ResourceThresholds>);
|
|
76
77
|
/**
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"resource-monitor.d.ts","sourceRoot":"","sources":["../../../../../backend/src/utils/resource-monitor.ts"],"names":[],"mappings":";AAEA,OAAO,EAAE,YAAY,EAAE,MAAM,QAAQ,CAAC;
|
|
1
|
+
{"version":3,"file":"resource-monitor.d.ts","sourceRoot":"","sources":["../../../../../backend/src/utils/resource-monitor.ts"],"names":[],"mappings":";AAEA,OAAO,EAAE,YAAY,EAAE,MAAM,QAAQ,CAAC;AAKtC;;GAEG;AACH,UAAU,kBAAkB;IAC3B,mCAAmC;IACnC,QAAQ,EAAE,MAAM,CAAC;IACjB,wCAAwC;IACxC,UAAU,EAAE,MAAM,CAAC;IACnB,+CAA+C;IAC/C,cAAc,EAAE,MAAM,CAAC;IACvB,qCAAqC;IACrC,SAAS,EAAE,MAAM,CAAC;CAClB;AAED;;GAEG;AACH,UAAU,eAAe;IACxB,iCAAiC;IACjC,aAAa,EAAE,MAAM,CAAC;IACtB,mCAAmC;IACnC,eAAe,EAAE,MAAM,CAAC;IACxB,6CAA6C;IAC7C,cAAc,EAAE,MAAM,CAAC;IACvB,sCAAsC;IACtC,SAAS,EAAE,MAAM,CAAC;IAClB,+BAA+B;IAC/B,aAAa,EAAE,MAAM,CAAC;IACtB,6BAA6B;IAC7B,iBAAiB,EAAE,MAAM,CAAC;IAC1B,mBAAmB;IACnB,WAAW,EAAE,MAAM,EAAE,CAAC;IACtB,gCAAgC;IAChC,oBAAoB,EAAE,MAAM,CAAC;CAC7B;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;;GA2BG;AACH,qBAAa,eAAgB,SAAQ,YAAY;IAChD,OAAO,CAAC,UAAU,CAAqB;IACvC,OAAO,CAAC,kBAAkB,CAA+B;IACzD,OAAO,CAAC,kBAAkB,CAAa;IACvC,OAAO,CAAC,YAAY,CAAsB;IAC1C,OAAO,CAAC,YAAY,CAAc;IAClC,OAAO,CAAC,aAAa,CAAgB;IACrC,OAAO,CAAC,UAAU,CAAgB;IAClC,OAAO,CAAC,YAAY,CAAkB;IACtC,OAAO,CAAC,MAAM,CAAkB;IAEhC,OAAO,CAAC,QAAQ,CAAC,kBAAkB,CAKjC;gBAEU,UAAU,CAAC,EAAE,OAAO,CAAC,kBAAkB,CAAC;IAQpD;;;;OAIG;IACH,KAAK,CAAC,UAAU,GAAE,MAAc,GAAG,IAAI;IAqBvC;;OAEG;IACH,IAAI,IAAI,IAAI;IAcZ;;;;OAIG;IACG,iBAAiB,IAAI,OAAO,CAAC,eAAe,CAAC;IAiBnD;;OAEG;YACW,gBAAgB;IAkC9B;;;;OAIG;IACH,OAAO,CAAC,UAAU;IAWlB;;;;OAIG;IACH,OAAO,CAAC,eAAe;IAkCvB;;;;OAIG;IACH,OAAO,CAAC,aAAa;IAkCrB;;;;;OAKG;IACH,OAAO,CAAC,sBAAsB;IAW9B;;;;OAIG;IACH,OAAO,CAAC,iBAAiB;IAgBzB;;;;OAIG;IACH,OAAO,CAAC,mBAAmB;IAW3B;;;;OAIG;YACW,gBAAgB;IAe9B;;;;OAIG;IACH,OAAO,CAAC,aAAa;IAYrB;;OAEG;IACH,OAAO,CAAC,wBAAwB;IAahC;;;;OAIG;IACG,oBAAoB,IAAI,OAAO,CAAC;QACrC,MAAM,EAAE,SAAS,GAAG,SAAS,GAAG,UAAU,CAAC;QAC3C,OAAO,EAAE,eAAe,CAAC;QACzB,eAAe,EAAE,MAAM,EAAE,CAAC;QAC1B,MAAM,EAAE;YACP,WAAW,EAAE,MAAM,CAAC;YACpB,QAAQ,EAAE,MAAM,CAAC;SACjB,CAAC;KACF,CAAC;IAgDF;;;;OAIG;IACH,gBAAgB,CAAC,aAAa,EAAE,OAAO,CAAC,kBAAkB,CAAC,GAAG,IAAI;IAKlE;;;;OAIG;IACH,aAAa,IAAI,kBAAkB;CAGnC;AAGD,YAAY,EAAE,kBAAkB,EAAE,eAAe,EAAE,CAAC"}
|
|
@@ -2,6 +2,7 @@
|
|
|
2
2
|
import { EventEmitter } from 'events';
|
|
3
3
|
import { execSync } from 'child_process';
|
|
4
4
|
import os from 'os';
|
|
5
|
+
import { LoggerService } from '../services/core/logger.service.js';
|
|
5
6
|
/**
|
|
6
7
|
* ResourceMonitor provides comprehensive monitoring of system resources
|
|
7
8
|
* to detect potential issues before they cause crashes.
|
|
@@ -24,7 +25,7 @@ import os from 'os';
|
|
|
24
25
|
* });
|
|
25
26
|
*
|
|
26
27
|
* monitor.on('warning', (metrics) => {
|
|
27
|
-
*
|
|
28
|
+
* // Handle resource warning
|
|
28
29
|
* });
|
|
29
30
|
*
|
|
30
31
|
* monitor.start();
|
|
@@ -39,6 +40,7 @@ export class ResourceMonitor extends EventEmitter {
|
|
|
39
40
|
memoryHistory = [];
|
|
40
41
|
cpuHistory = [];
|
|
41
42
|
isMonitoring = false;
|
|
43
|
+
logger;
|
|
42
44
|
DEFAULT_THRESHOLDS = {
|
|
43
45
|
memoryMB: 500, // 500MB memory warning
|
|
44
46
|
cpuPercent: 80, // 80% CPU warning
|
|
@@ -47,8 +49,9 @@ export class ResourceMonitor extends EventEmitter {
|
|
|
47
49
|
};
|
|
48
50
|
constructor(thresholds) {
|
|
49
51
|
super();
|
|
52
|
+
this.logger = LoggerService.getInstance().createComponentLogger('ResourceMonitor');
|
|
50
53
|
this.thresholds = { ...this.DEFAULT_THRESHOLDS, ...thresholds };
|
|
51
|
-
|
|
54
|
+
this.logger.info('Resource Monitor initialized', { thresholds: this.thresholds });
|
|
52
55
|
}
|
|
53
56
|
/**
|
|
54
57
|
* Start resource monitoring
|
|
@@ -57,10 +60,10 @@ export class ResourceMonitor extends EventEmitter {
|
|
|
57
60
|
*/
|
|
58
61
|
start(intervalMs = 30000) {
|
|
59
62
|
if (this.isMonitoring) {
|
|
60
|
-
|
|
63
|
+
this.logger.warn('Resource monitoring is already running');
|
|
61
64
|
return;
|
|
62
65
|
}
|
|
63
|
-
|
|
66
|
+
this.logger.info('Starting resource monitoring', { intervalMs });
|
|
64
67
|
this.isMonitoring = true;
|
|
65
68
|
// Initial measurement
|
|
66
69
|
this.measureResources();
|
|
@@ -78,7 +81,7 @@ export class ResourceMonitor extends EventEmitter {
|
|
|
78
81
|
if (!this.isMonitoring) {
|
|
79
82
|
return;
|
|
80
83
|
}
|
|
81
|
-
|
|
84
|
+
this.logger.info('Stopping resource monitoring');
|
|
82
85
|
this.isMonitoring = false;
|
|
83
86
|
if (this.monitoringInterval) {
|
|
84
87
|
clearInterval(this.monitoringInterval);
|
|
@@ -131,7 +134,7 @@ export class ResourceMonitor extends EventEmitter {
|
|
|
131
134
|
this.emit('metrics', metrics);
|
|
132
135
|
}
|
|
133
136
|
catch (error) {
|
|
134
|
-
|
|
137
|
+
this.logger.error('Error measuring resources', { error: error instanceof Error ? error.message : String(error) });
|
|
135
138
|
this.emit('error', error);
|
|
136
139
|
}
|
|
137
140
|
}
|
|
@@ -141,13 +144,14 @@ export class ResourceMonitor extends EventEmitter {
|
|
|
141
144
|
* @param metrics - Current resource metrics
|
|
142
145
|
*/
|
|
143
146
|
logMetrics(metrics) {
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
147
|
+
this.logger.debug('Resource Metrics', {
|
|
148
|
+
memoryMB: metrics.memoryUsageMB,
|
|
149
|
+
cpuPercent: parseFloat(metrics.cpuUsagePercent.toFixed(1)),
|
|
150
|
+
eventLoopLagMs: parseFloat(metrics.eventLoopLagMs.toFixed(1)),
|
|
151
|
+
openFiles: metrics.openFiles,
|
|
152
|
+
freeMemoryPercent: parseFloat(metrics.freeMemoryPercent.toFixed(1)),
|
|
153
|
+
loadAverage: metrics.loadAverage.map(l => parseFloat(l.toFixed(2))),
|
|
154
|
+
});
|
|
151
155
|
}
|
|
152
156
|
/**
|
|
153
157
|
* Check if metrics exceed thresholds and emit warnings
|
|
@@ -172,8 +176,7 @@ export class ResourceMonitor extends EventEmitter {
|
|
|
172
176
|
warnings.push(`Low system memory: ${metrics.freeMemoryPercent.toFixed(1)}% free`);
|
|
173
177
|
}
|
|
174
178
|
if (warnings.length > 0) {
|
|
175
|
-
|
|
176
|
-
warnings.forEach(warning => console.warn(` ${warning}`));
|
|
179
|
+
this.logger.warn('Resource warnings detected', { warnings });
|
|
177
180
|
this.emit('warning', {
|
|
178
181
|
warnings,
|
|
179
182
|
metrics,
|
|
@@ -191,7 +194,10 @@ export class ResourceMonitor extends EventEmitter {
|
|
|
191
194
|
if (this.memoryHistory.length >= 5) {
|
|
192
195
|
const avgGrowth = this.calculateAverageGrowth(this.memoryHistory);
|
|
193
196
|
if (avgGrowth > 10) { // Growing by more than 10MB per measurement
|
|
194
|
-
|
|
197
|
+
this.logger.warn('Potential memory leak detected', {
|
|
198
|
+
averageGrowthMB: parseFloat(avgGrowth.toFixed(1)),
|
|
199
|
+
currentMemoryMB: metrics.memoryUsageMB,
|
|
200
|
+
});
|
|
195
201
|
this.emit('memory_leak_warning', {
|
|
196
202
|
averageGrowth: avgGrowth,
|
|
197
203
|
currentMemory: metrics.memoryUsageMB,
|
|
@@ -204,7 +210,10 @@ export class ResourceMonitor extends EventEmitter {
|
|
|
204
210
|
const recentCpu = this.cpuHistory.slice(-3);
|
|
205
211
|
const avgCpu = recentCpu.reduce((a, b) => a + b, 0) / recentCpu.length;
|
|
206
212
|
if (avgCpu > this.thresholds.cpuPercent) {
|
|
207
|
-
|
|
213
|
+
this.logger.warn('Sustained high CPU usage', {
|
|
214
|
+
averageCpuPercent: parseFloat(avgCpu.toFixed(1)),
|
|
215
|
+
measurements: 3,
|
|
216
|
+
});
|
|
208
217
|
this.emit('cpu_spike_warning', {
|
|
209
218
|
averageCpu: avgCpu,
|
|
210
219
|
recentReadings: recentCpu
|
|
@@ -306,7 +315,7 @@ export class ResourceMonitor extends EventEmitter {
|
|
|
306
315
|
return;
|
|
307
316
|
const lag = await this.measureEventLoopLag();
|
|
308
317
|
if (lag > this.thresholds.eventLoopLagMs) {
|
|
309
|
-
|
|
318
|
+
this.logger.warn('High event loop lag', { lagMs: parseFloat(lag.toFixed(1)) });
|
|
310
319
|
this.emit('event_loop_lag', { lag });
|
|
311
320
|
}
|
|
312
321
|
}, 5000);
|
|
@@ -364,7 +373,7 @@ export class ResourceMonitor extends EventEmitter {
|
|
|
364
373
|
*/
|
|
365
374
|
updateThresholds(newThresholds) {
|
|
366
375
|
this.thresholds = { ...this.thresholds, ...newThresholds };
|
|
367
|
-
|
|
376
|
+
this.logger.info('Updated resource monitoring thresholds', { thresholds: this.thresholds });
|
|
368
377
|
}
|
|
369
378
|
/**
|
|
370
379
|
* Get current thresholds
|
|
@@ -378,25 +387,26 @@ export class ResourceMonitor extends EventEmitter {
|
|
|
378
387
|
// If this script is run directly, start monitoring
|
|
379
388
|
const _isMainModule = process.argv[1]?.endsWith('resource-monitor.ts') || process.argv[1]?.endsWith('resource-monitor.js');
|
|
380
389
|
if (_isMainModule) {
|
|
390
|
+
const logger = LoggerService.getInstance().createComponentLogger('ResourceMonitor');
|
|
381
391
|
const monitor = new ResourceMonitor();
|
|
382
392
|
monitor.on('warning', (data) => {
|
|
383
|
-
|
|
393
|
+
logger.warn('Resource Warning', { data });
|
|
384
394
|
});
|
|
385
395
|
monitor.on('memory_leak_warning', (data) => {
|
|
386
|
-
|
|
396
|
+
logger.warn('Memory Leak Warning', { data });
|
|
387
397
|
});
|
|
388
398
|
monitor.on('cpu_spike_warning', (data) => {
|
|
389
|
-
|
|
399
|
+
logger.warn('CPU Spike Warning', { data });
|
|
390
400
|
});
|
|
391
401
|
monitor.start();
|
|
392
402
|
// Generate health report every 5 minutes
|
|
393
403
|
setInterval(async () => {
|
|
394
404
|
const report = await monitor.generateHealthReport();
|
|
395
|
-
|
|
405
|
+
logger.info('Health Report', { report });
|
|
396
406
|
}, 300000);
|
|
397
407
|
// Graceful shutdown
|
|
398
408
|
process.on('SIGINT', () => {
|
|
399
|
-
|
|
409
|
+
logger.info('Shutting down resource monitor');
|
|
400
410
|
monitor.stop();
|
|
401
411
|
process.exit(0);
|
|
402
412
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"resource-monitor.js","sourceRoot":"","sources":["../../../../../backend/src/utils/resource-monitor.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"resource-monitor.js","sourceRoot":"","sources":["../../../../../backend/src/utils/resource-monitor.ts"],"names":[],"mappings":"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"}
|