Detailed explanation and examples for this cron schedule pattern
Standard 5-field cron expression for Unix systems, crontab, and most platforms
0 0 1W * *6-field format with seconds for Java Quartz, Spring Boot, and enterprise applications
0 0 0 1W * ?0 0 1W * *minute hour day-of-month month day-of-week
0 0 0 1W * ?second minute hour day-of-month month day-of-week
0 0 0 1W * ? *second minute hour day-of-month month day-of-week year
0 0 1W * *Using month and day-of-week names where applicable
0 0 1W * * /path/to/commandStandard Unix crontab entry format
cron: '0 0 1W * *'GitHub Actions workflow schedule format
cron(0 0 1W \* \*)AWS CloudWatch Events cron expression format
0 0 1W * *Google Cloud Scheduler cron format
"schedule": "0 0 1W * *"Azure Functions cron format
cron: '0 0 1W * *'DigitalOcean App Platform cron format
schedule: "0 0 1W * *"Kubernetes CronJob schedule format
placement: { constraints: [node.role == manager] }
labels: { cron: "0 0 1W * *" }Docker Swarm service labels for cron scheduling
CronScheduleBuilder.cronSchedule("0 0 1W * *")Java Quartz scheduler format
cron.schedule('0 0 1W * *', function() {
// Your code here
});Node.js node-cron library format
from crontab import CronTab
cron = CronTab(user='username')
job = cron.new(command='/path/to/command')
job.setall('0 0 1W * *')Python python-crontab library format
# config/packages/messenger.yaml
framework:
messenger:
transports:
cron: '%env(MESSENGER_TRANSPORT_DSN)%'
options:
cron_expression: '0 0 1W * *'PHP Symfony Messenger cron expression format
This cron expression is composed of 5 time/date fields:
| Field | Value | Description |
|---|---|---|
| Minute | 0 | 0 |
| Hour | 0 | 0 |
| Day of Month | 1W | 1W |
| Month | * | Every month (1-12) |
| Day of Week | * | Every day of the week (0-6, where 0 is Sunday) |
In Quartz, we add a seconds field (and can replace * with ? in day-of-week):
| Field | Value | Description |
|---|---|---|
| Second | 0 | 0 |
| Minute | 0 | 0 |
| Hour | 0 | 0 |
| Day of Month | 1W | 1W |
| Month | * | Every month (1-12) |
| Day of Week | ? | Any value (no specific value) |
AWS CloudWatch Events adds an optional year field:
| Field | Value | Description |
|---|---|---|
| Minute | 0 | 0 |
| Hour | 0 | 0 |
| Day of Month | 1W | 1W |
| Month | * | Every month (1-12) |
| Day of Week | * | Every day of the week (0-6, where 0 is Sunday) |
| Year (Optional) | * | Every year |
Note that different systems interpret cron expressions slightly differently. The standard Unix format has 5 fields, while Quartz and AWS formats have additional fields. Some special characters like ?, L, W, and # are only supported in specific implementations.
This job runs on a custom schedule