Let's walk through a practical example of setting up a simple job queue. We'll create a task that sends a welcome email when a user signs up.
You might wonder: "Why not just send the email directly in the afterChange hook?"
Now let's build this example step by step.
First, create a task in your payload.config.ts:
This defines a reusable task with a unique slug, an inputSchema that validates and types the input data, and a handler function containing the work to be performed. The retries option ensures the task will automatically retry up to 3 times if it fails. Learn more about Tasks.
This uses payload.jobs.queue() to create a job instance from the task definition. The job is added to the queue immediately but runs asynchronously, so the API response returns right away without waiting for the email to send. Jobs are stored in the database as documents in the payload-jobs collection.
The autoRun configuration automatically processes queued jobs on a schedule using cron syntax. In this example, Payload checks for pending jobs every 5 minutes and executes them. Alternatively, you can manually trigger job processing with payload.jobs.run() or use the API endpoint for serverless platforms.
That's it! Now when users sign up, a job is queued and will be processed within 5 minutes without blocking the API response.
The previous example showed manual job queuing (jobs triggered by user actions). Now let's look at a job that runs automatically on a schedule without any user action.
We'll create a task that generates a daily analytics report every morning at 8 AM.
The schedule property defines when this job should run (every day at 8 AM).
To actually queue and execute scheduled jobs, you need to configure the autoRun property. This handles both queuing jobs based on their schedule and running them:
Here's the complete flow:
schedule configuration automatically queues a new job in the 'reports' queueautoRun cron checks the 'reports' queue and finds the jobHere's the full config with both the task and runner:
Approach | When to Use | Example |
|---|---|---|
Manual Queuing | Jobs triggered by user actions or data changes | Welcome emails, payment processing, notifications |
Scheduled Jobs | Jobs that run automatically at regular intervals | Daily reports, weekly cleanups, nightly syncs |
Scheduled with Future | One-time job in the future | Publish post at 3pm tomorrow, trial expiry reminders |
For scheduled jobs with waitUntil:
This is different from the schedule property, which repeats automatically.
See Job Schedules for more details on scheduling options and advanced patterns.