Cron Triggers
Cron Triggers allow users to map a cron expression to a Worker using a scheduled() handler that enables Workers to be executed on a schedule.
Cron Triggers are ideal for running periodic jobs, such as for maintenance or calling third-party APIs to collect up-to-date data. Workers scheduled by Cron Triggers will run on underutilized machines to make the best use of Cloudflare's capacity and route traffic efficiently.
Cron Triggers execute on UTC time.
To respond to a Cron Trigger, you must add a "scheduled" handler to your Worker.
export default {  async scheduled(controller, env, ctx) {    console.log("cron processed");  },};interface Env {}export default {  async scheduled(    controller: ScheduledController,    env: Env,    ctx: ExecutionContext,  ) {    console.log("cron processed");  },};from workers import handler
@handlerasync def on_scheduled(controller, env, ctx):  print("cron processed")Refer to the following additional examples to write your code:
After you have updated your Worker code to include a "scheduled" event, you must update your Worker project configuration.
Via the Wrangler configuration file
If a Worker is managed with Wrangler, Cron Triggers should be exclusively managed through the Wrangler configuration file.
Refer to the example below for a Cron Triggers configuration:
{  "triggers": {    "crons": [      "*/3 * * * *",      "0 15 1 * *",      "59 23 LW * *"    ]  }}[triggers]# Schedule cron triggers:# - At every 3rd minute# - At 15:00 (UTC) on first day of the month# - At 23:59 (UTC) on the last weekday of the monthcrons = [ "*/3 * * * *", "0 15 1 * *", "59 23 LW * *" ]You also can set a different Cron Trigger for each environment in your Wrangler configuration file. You need to put the triggers array under your chosen environment. For example:
{  "env": {    "dev": {      "triggers": {        "crons": [          "0 * * * *"        ]      }    }  }}[env.dev.triggers]crons = ["0 * * * *"]To add Cron Triggers in the Cloudflare dashboard:
- 
In the Cloudflare dashboard, go to the Workers & Pages page. Go to Workers & Pages
- 
In Overview, select your Worker > Settings > Triggers > Cron Triggers. 
Cloudflare supports cron expressions with five fields, along with most Quartz scheduler ↗-like cron syntax extensions:
| Field | Values | Characters | 
|---|---|---|
| Minute | 0-59 | * , - / | 
| Hours | 0-23 | * , - / | 
| Days of Month | 1-31 | * , - / L W | 
| Months | 1-12, case-insensitive 3-letter abbreviations ("JAN", "aug", etc.) | * , - / | 
| Weekdays | 1-7, case-insensitive 3-letter abbreviations ("MON", "fri", etc.) | * , - / L # | 
Some common time intervals that may be useful for setting up your Cron Trigger:
- 
* * * * *- At every minute
 
- 
*/30 * * * *- At every 30th minute
 
- 
45 * * * *- On the 45th minute of every hour
 
- 
0 17 * * sunor0 17 * * 1- 17:00 (UTC) on Sunday
 
- 
10 7 * * mon-frior10 7 * * 2-6- 07:10 (UTC) on weekdays
 
- 
0 15 1 * *- 15:00 (UTC) on first day of the month
 
- 
0 18 * * 6Lor0 18 * * friL- 18:00 (UTC) on the last Friday of the month
 
- 
59 23 LW * *- 23:59 (UTC) on the last weekday of the month
 
Test Cron Triggers using Wrangler with wrangler dev, or using the Cloudflare Vite plugin ↗. This will expose a /cdn-cgi/handler/scheduled route which can be used to test using a HTTP request.
curl "http://localhost:8787/cdn-cgi/handler/scheduled"To simulate different cron patterns, a cron query parameter can be passed in.
curl "http://localhost:8787/cdn-cgi/handler/scheduled?cron=*+*+*+*+*"Optionally, you can also pass a time query parameter to override controller.scheduledTime in your scheduled event listener.
curl "http://localhost:8787/cdn-cgi/handler/scheduled?cron=*+*+*+*+*&time=1745856238"To view the execution history of Cron Triggers, view Cron Events:
- 
In the Cloudflare dashboard, go to the Workers & Pages page. Go to Workers & Pages
- 
In Overview, select your Worker. 
- 
Select Settings. 
- 
Under Trigger Events, select View events. 
Cron Events stores the 100 most recent invocations of the Cron scheduled event. Workers Logs also records invocation logs for the Cron Trigger with a longer retention period and a filter & query interface. If you are interested in an API to access Cron Events, use Cloudflare's GraphQL Analytics API.
Refer to Metrics and Analytics for more information.
To delete a Cron Trigger on a deployed Worker via the dashboard:
- 
In the Cloudflare dashboard, go to the Workers & Pages page. Go to Workers & Pages
- 
Select your Worker. 
- 
Go to Triggers > select the three dot icon next to the Cron Trigger you want to remove > Delete. 
Via the Wrangler configuration file
If a Worker is managed with Wrangler, Cron Triggers should be exclusively managed through the Wrangler configuration file.
When deploying a Worker with Wrangler any previous Cron Triggers are replaced with those specified in the triggers array.
- If the cronsproperty is an empty array then all the Cron Triggers are removed.
- If the triggersorcronsproperty areundefinedthen the currently deploy Cron Triggers are left in-place.
{  "triggers": {    "crons": []  }}[triggers]# Remove all cron triggers:crons = [ ]Refer to Limits to track the maximum number of Cron Triggers per Worker.
With Green Compute enabled, your Cron Triggers will only run on Cloudflare points of presence that are located in data centers that are powered purely by renewable energy. Organizations may claim that they are powered by 100 percent renewable energy if they have procured sufficient renewable energy to account for their overall energy use.
Renewable energy can be purchased in a number of ways, including through on-site generation (wind turbines, solar panels), directly from renewable energy producers through contractual agreements called Power Purchase Agreements (PPA), or in the form of Renewable Energy Credits (REC, IRECs, GoOs) from an energy credit market.
Green Compute can be configured at the account level:
- 
In the Cloudflare dashboard, go to the Workers & Pages page. Go to Workers & Pages
- 
In the Account details section, find Compute Setting. 
- 
Select Change. 
- 
Select Green Compute. 
- 
Select Confirm. 
- Triggers - Review Wrangler configuration file syntax for Cron Triggers.
- Learn how to access Cron Triggers in ES modules syntax for an optimized experience.
Was this helpful?
- Resources
- API
- New to Cloudflare?
- Directory
- Sponsorships
- Open Source
- Support
- Help Center
- System Status
- Compliance
- GDPR
- Company
- cloudflare.com
- Our team
- Careers
- © 2025 Cloudflare, Inc.
- Privacy Policy
- Terms of Use
- Report Security Issues
- Trademark