summaryrefslogtreecommitdiff
path: root/packages/backend/src/boot/worker.ts
diff options
context:
space:
mode:
authorsyuilo <4439005+syuilo@users.noreply.github.com>2024-06-06 11:20:54 +0900
committersyuilo <4439005+syuilo@users.noreply.github.com>2024-06-06 11:20:54 +0900
commitab69e113f4921462b72f1f352dfefe52b37862f5 (patch)
tree61f728a2967d4a96ac64a5ca5b4d199822880ac2 /packages/backend/src/boot/worker.ts
parentfix (diff)
downloadsharkey-ab69e113f4921462b72f1f352dfefe52b37862f5.tar.gz
sharkey-ab69e113f4921462b72f1f352dfefe52b37862f5.tar.bz2
sharkey-ab69e113f4921462b72f1f352dfefe52b37862f5.zip
enhance(backend): improve sentry integration
Diffstat (limited to 'packages/backend/src/boot/worker.ts')
-rw-r--r--packages/backend/src/boot/worker.ts23
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) {