Skip to content

Add crons integration extending OpenTelementry and remove Sentry cron wrapper #11790

@s1gr1d

Description

@s1gr1d

Problem Statement

The current setup for monitoring crons requires a wrapper function (link to docs). You use it like this:

const CronJobWithCheckIn = Sentry.cron.instrumentCron(CronJob, 'cron_slug');

const job = CronJobWithCheckIn.from({
  cronTime: '7 * * * * *',
  onTick: () => {
    console.log('cron: Job is running every few seconds');
  },
});

job.start();

Solution Brainstorm

We could add a new integration which is extending OpenTelementry and publish it as separate packages and remove the wrapper, which is currently needed. These OTEL instrumentations can also automatically create spans, something that is not supported atm.

If we make these integrations, we need them to be opt-in because crons charge per monitor. We have two options:

  1. Have users explicitly add integrations, with ability to specify monitors they are only interested in
  2. Have all cron integrations enabled by default, but expose a public API options surface to manage what monitors are created.
### Phase 1: Initial Implementation
- [ ] Add `@sentry/opentelemetry-instrumentation-cron`
- [ ] Add `@sentry/opentelemetry-instrumentation-node-cron`
- [ ] Add `@sentry/opentelemetry-instrumentation-node-schedule`
- [ ] Add integration for `cron`
- [ ] Add integration for `node-cron`
- [ ] Add integration for `node-schedule`
### Phase 1: Migration
- [ ] Update docs
- [ ] Deprecate `Sentry.cron` methods

Metadata

Metadata

Assignees

No one assigned

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions