UNPKG

n8n

Version:

n8n Workflow Automation Tool

185 lines 8.74 kB
"use strict"; var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { if (k2 === undefined) k2 = k; var desc = Object.getOwnPropertyDescriptor(m, k); if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { desc = { enumerable: true, get: function() { return m[k]; } }; } Object.defineProperty(o, k2, desc); }) : (function(o, m, k, k2) { if (k2 === undefined) k2 = k; o[k2] = m[k]; })); var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { Object.defineProperty(o, "default", { enumerable: true, value: v }); }) : function(o, v) { o["default"] = v; }); var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; var __importStar = (this && this.__importStar) || (function () { var ownKeys = function(o) { ownKeys = Object.getOwnPropertyNames || function (o) { var ar = []; for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k; return ar; }; return ownKeys(o); }; return function (mod) { if (mod && mod.__esModule) return mod; var result = {}; if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]); __setModuleDefault(result, mod); return result; }; })(); var __metadata = (this && this.__metadata) || function (k, v) { if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); }; var __importDefault = (this && this.__importDefault) || function (mod) { return (mod && mod.__esModule) ? mod : { "default": mod }; }; Object.defineProperty(exports, "__esModule", { value: true }); exports.Worker = void 0; const backend_common_1 = require("@n8n/backend-common"); const decorators_1 = require("@n8n/decorators"); const di_1 = require("@n8n/di"); const zod_1 = require("zod"); const config_1 = __importDefault(require("../config")); const constants_1 = require("../constants"); const event_message_generic_1 = require("../eventbus/event-message-classes/event-message-generic"); const message_event_bus_1 = require("../eventbus/message-event-bus/message-event-bus"); const log_streaming_event_relay_1 = require("../events/relays/log-streaming.event-relay"); const publisher_service_1 = require("../scaling/pubsub/publisher.service"); const pubsub_registry_1 = require("../scaling/pubsub/pubsub.registry"); const subscriber_service_1 = require("../scaling/pubsub/subscriber.service"); const worker_status_service_ee_1 = require("../scaling/worker-status.service.ee"); const base_command_1 = require("./base-command"); const flagsSchema = zod_1.z.object({ concurrency: zod_1.z.number().int().default(10).describe('How many jobs can run in parallel.'), }); let Worker = class Worker extends base_command_1.BaseCommand { async stopProcess() { this.logger.info('Stopping worker...'); try { await this.externalHooks?.run('n8n.stop'); } catch (error) { await this.exitWithCrash('Error shutting down worker', error); } await this.exitSuccessFully(); } constructor() { if (config_1.default.getEnv('executions.mode') !== 'queue') { config_1.default.set('executions.mode', 'queue'); } super(); this.needsCommunityPackages = true; this.needsTaskRunner = true; this.logger = this.logger.scoped('scaling'); } async init() { const { QUEUE_WORKER_TIMEOUT } = process.env; if (QUEUE_WORKER_TIMEOUT) { this.gracefulShutdownTimeoutInS = parseInt(QUEUE_WORKER_TIMEOUT, 10) || this.globalConfig.queue.bull.gracefulShutdownTimeout; this.logger.warn('QUEUE_WORKER_TIMEOUT has been deprecated. Rename it to N8N_GRACEFUL_SHUTDOWN_TIMEOUT.'); } await this.initCrashJournal(); this.logger.debug('Starting n8n worker...'); this.logger.debug(`Host ID: ${this.instanceSettings.hostId}`); await this.setConcurrency(); await super.init(); await this.initLicense(); this.logger.debug('License init complete'); await this.initBinaryDataService(); this.logger.debug('Binary data service init complete'); await this.initDataDeduplicationService(); this.logger.debug('Data deduplication service init complete'); await this.initExternalHooks(); this.logger.debug('External hooks init complete'); await this.initEventBus(); this.logger.debug('Event bus init complete'); await this.initScalingService(); await this.initOrchestration(); this.logger.debug('Orchestration init complete'); await di_1.Container.get(message_event_bus_1.MessageEventBus).send(new event_message_generic_1.EventMessageGeneric({ eventName: 'n8n.worker.started', payload: { workerId: this.instanceSettings.hostId, }, })); await this.moduleRegistry.initModules(); } async initEventBus() { await di_1.Container.get(message_event_bus_1.MessageEventBus).initialize({ workerId: this.instanceSettings.hostId, }); di_1.Container.get(log_streaming_event_relay_1.LogStreamingEventRelay).init(); } async initOrchestration() { di_1.Container.get(publisher_service_1.Publisher); di_1.Container.get(pubsub_registry_1.PubSubRegistry).init(); await di_1.Container.get(subscriber_service_1.Subscriber).subscribe('n8n.commands'); di_1.Container.get(worker_status_service_ee_1.WorkerStatusService); } async setConcurrency() { const { flags } = this; const envConcurrency = config_1.default.getEnv('executions.concurrency.productionLimit'); this.concurrency = envConcurrency !== -1 ? envConcurrency : flags.concurrency; if (this.concurrency < 5) { this.logger.warn('Concurrency is set to less than 5. THIS CAN LEAD TO AN UNSTABLE ENVIRONMENT. Please consider increasing it to at least 5 to make best use of the worker.'); } } async initScalingService() { const { ScalingService } = await Promise.resolve().then(() => __importStar(require('../scaling/scaling.service'))); this.scalingService = di_1.Container.get(ScalingService); await this.scalingService.setupQueue(); this.scalingService.setupWorker(this.concurrency); } async run() { this.logger.info('\nn8n worker is now ready'); this.logger.info(` * Version: ${constants_1.N8N_VERSION}`); this.logger.info(` * Concurrency: ${this.concurrency}`); this.logger.info(''); const endpointsConfig = { health: this.globalConfig.queue.health.active, overwrites: this.globalConfig.credentials.overwrite.endpoint !== '', metrics: this.globalConfig.endpoints.metrics.enable, }; if (Object.values(endpointsConfig).some((e) => e)) { const { WorkerServer } = await Promise.resolve().then(() => __importStar(require('../scaling/worker-server'))); await di_1.Container.get(WorkerServer).init(endpointsConfig); } if (!backend_common_1.inTest && process.stdout.isTTY) { process.stdin.setRawMode(true); process.stdin.resume(); process.stdin.setEncoding('utf8'); process.stdin.on('data', (key) => { if (key.charCodeAt(0) === 3) process.kill(process.pid, 'SIGINT'); }); } if (!backend_common_1.inTest) await new Promise(() => { }); } async catch(error) { await this.exitWithCrash('Worker exiting due to an error.', error); } }; exports.Worker = Worker; exports.Worker = Worker = __decorate([ (0, decorators_1.Command)({ name: 'worker', description: 'Starts a n8n worker', examples: ['--concurrency=5'], flagsSchema, }), __metadata("design:paramtypes", []) ], Worker); //# sourceMappingURL=worker.js.map