Open
Description
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:
- Have users explicitly add integrations, with ability to specify monitors they are only interested in
- 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