X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=server%2Flib%2Fworker%2Fparent-process.ts;h=4bc7f26207f97a44852f03bc1e2c54d78a546534;hb=b37d80e3ced7d731bf0a0e985258041419cd972a;hp=65300bbc880f39744517d63b43eff3d75f75beb9;hpb=ccd62a45024d90c004d0d38737fef055b3fe22b7;p=github%2FChocobozzz%2FPeerTube.git diff --git a/server/lib/worker/parent-process.ts b/server/lib/worker/parent-process.ts index 65300bbc8..4bc7f2620 100644 --- a/server/lib/worker/parent-process.ts +++ b/server/lib/worker/parent-process.ts @@ -1,28 +1,36 @@ import { join } from 'path' import Piscina from 'piscina' +import { processImage } from '@server/helpers/image-utils' import { WORKER_THREADS } from '@server/initializers/constants' import { downloadImage } from './workers/image-downloader' -import { processImage } from '@server/helpers/image-utils' -const downloadImagerWorker = new Piscina({ - filename: join(__dirname, 'workers', 'image-downloader.js'), - concurrentTasksPerWorker: WORKER_THREADS.DOWNLOAD_IMAGE.CONCURRENCY, - maxThreads: WORKER_THREADS.DOWNLOAD_IMAGE.MAX_THREADS -}) +let downloadImageWorker: Piscina function downloadImageFromWorker (options: Parameters[0]): Promise> { - return downloadImagerWorker.run(options) + if (!downloadImageWorker) { + downloadImageWorker = new Piscina({ + filename: join(__dirname, 'workers', 'image-downloader.js'), + concurrentTasksPerWorker: WORKER_THREADS.DOWNLOAD_IMAGE.CONCURRENCY, + maxThreads: WORKER_THREADS.DOWNLOAD_IMAGE.MAX_THREADS + }) + } + + return downloadImageWorker.run(options) } // --------------------------------------------------------------------------- -const processImageWorker = new Piscina({ - filename: join(__dirname, 'workers', 'image-processor.js'), - concurrentTasksPerWorker: WORKER_THREADS.PROCESS_IMAGE.CONCURRENCY, - maxThreads: WORKER_THREADS.PROCESS_IMAGE.MAX_THREADS -}) +let processImageWorker: Piscina function processImageFromWorker (options: Parameters[0]): Promise> { + if (!processImageWorker) { + processImageWorker = new Piscina({ + filename: join(__dirname, 'workers', 'image-processor.js'), + concurrentTasksPerWorker: WORKER_THREADS.PROCESS_IMAGE.CONCURRENCY, + maxThreads: WORKER_THREADS.PROCESS_IMAGE.MAX_THREADS + }) + } + return processImageWorker.run(options) }