feat(server): run microservices in worker thread (#9426)

feat: start microservices in worker thread and add internal microservices for the server
This commit is contained in:
Zack Pollard 2024-05-14 15:28:20 +01:00 committed by GitHub
parent 3d5e55bdaa
commit 1ea55d642e
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
6 changed files with 79 additions and 17 deletions

View file

@ -0,0 +1,32 @@
import { NestFactory } from '@nestjs/core';
import { isMainThread } from 'node:worker_threads';
import { MicroservicesModule } from 'src/app.module';
import { envName, serverVersion } from 'src/constants';
import { ILoggerRepository } from 'src/interfaces/logger.interface';
import { WebSocketAdapter } from 'src/middleware/websocket.adapter';
import { otelSDK } from 'src/utils/instrumentation';
const host = process.env.HOST;
export async function bootstrapMicroservices() {
otelSDK.start();
const port = Number(process.env.MICROSERVICES_PORT) || 3002;
const app = await NestFactory.create(MicroservicesModule, { bufferLogs: true });
const logger = await app.resolve(ILoggerRepository);
logger.setAppName('ImmichMicroservices');
logger.setContext('ImmichMicroservices');
app.useLogger(logger);
app.useWebSocketAdapter(new WebSocketAdapter(app));
await (host ? app.listen(port, host) : app.listen(port));
logger.log(`Immich Microservices is listening on ${await app.getUrl()} [v${serverVersion}] [${envName}] `);
}
if (!isMainThread) {
bootstrapMicroservices().catch((error) => {
console.error(error);
process.exit(1);
});
}