diff options
| author | syuilo <4439005+syuilo@users.noreply.github.com> | 2024-06-06 11:20:54 +0900 |
|---|---|---|
| committer | syuilo <4439005+syuilo@users.noreply.github.com> | 2024-06-06 11:20:54 +0900 |
| commit | ab69e113f4921462b72f1f352dfefe52b37862f5 (patch) | |
| tree | 61f728a2967d4a96ac64a5ca5b4d199822880ac2 /packages/backend/src/boot | |
| parent | fix (diff) | |
| download | sharkey-ab69e113f4921462b72f1f352dfefe52b37862f5.tar.gz sharkey-ab69e113f4921462b72f1f352dfefe52b37862f5.tar.bz2 sharkey-ab69e113f4921462b72f1f352dfefe52b37862f5.zip | |
enhance(backend): improve sentry integration
Diffstat (limited to 'packages/backend/src/boot')
| -rw-r--r-- | packages/backend/src/boot/worker.ts | 23 |
1 files changed, 23 insertions, 0 deletions
diff --git a/packages/backend/src/boot/worker.ts b/packages/backend/src/boot/worker.ts index d4a7cd56e5..5d4a15b29f 100644 --- a/packages/backend/src/boot/worker.ts +++ b/packages/backend/src/boot/worker.ts @@ -4,13 +4,36 @@ */ import cluster from 'node:cluster'; +import * as Sentry from '@sentry/node'; +import { nodeProfilingIntegration } from '@sentry/profiling-node'; import { envOption } from '@/env.js'; +import { loadConfig } from '@/config.js'; import { jobQueue, server } from './common.js'; /** * Init worker process */ export async function workerMain() { + const config = loadConfig(); + + if (config.sentryForBackend) { + Sentry.init({ + integrations: [ + ...(config.sentryForBackend.enableNodeProfiling ? [nodeProfilingIntegration()] : []), + ], + + // Performance Monitoring + tracesSampleRate: 1.0, // Capture 100% of the transactions + + // Set sampling rate for profiling - this is relative to tracesSampleRate + profilesSampleRate: 1.0, + + maxBreadcrumbs: 0, + + ...config.sentryForBackend.options, + }); + } + if (envOption.onlyServer) { await server(); } else if (envOption.onlyQueue) { |