Skip to main content

Cloud Cron Quickstart

Let's say you want to run some code on a schedule. For example, you want to:

  • Record a stock's price once a minute.
  • Migrate some data from one database to another once an hour.
  • Send emails to inactive users once a week.

This kind of code isn't easy to manage because the server running it has to always be "on"—you can't just run it on your laptop.

In this tutorial, we'll show you how to use DBOS to run code on a schedule in the cloud so you don't have to worry about maintaining it. You'll learn how to write a scheduled (cron) function in just 11 lines of Python code and deploy it to the cloud with a single click.

Tutorial

1. Select the Cloud Cron Starter

Visit https://console.dbos.dev/launch and select the DBOS Cron Starter. When prompted, create a database for your app with default settings.

Cloud Console Templates

2. Connect to GitHub and Deploy to DBOS Cloud

To ensure you can easily update your project after deploying it, DBOS will create a GitHub repository for you. You can deploy directly from that GitHub repository to DBOS Cloud.

First, sign in to your GitHub account. Then, set your repository name and whether it should be public or private.

Next, click "Create GitHub Repo and Deploy" and DBOS will clone a copy of the source code into your GitHub account, then deploy your project to DBOS Cloud. In less than a minute, your app should deploy successfully.

Deploy with GitHub

3. View Your Application

At this point, your app is running code on a schedule in the cloud!

To see its code, visit your new GitHub repository and open app/main.py. The app schedules a function incrementing a counter to run once a minute (the cron syntax * * * * * means "once a minute"). You can visit your app's URL to see the current value of the counter.

from dbos import DBOS
from fastapi import FastAPI

app = FastAPI()
DBOS(fastapi=app)
counter = 0

@DBOS.scheduled("* * * * *")
@DBOS.step()
def scheduled_function(scheduled_time, actual_time):
global counter
counter += 1

@app.get("/")
def endpoint():
return f"The scheduled function has run {counter} times!"

4. Start Building

To start building, edit your application on GitHub (source code is in app/main.py), commit your changes, then press "Deploy From GitHub" on your applications page to see your changes reflected in the live application.

Not sure where to start? Try adding this line to the scheduled function so it logs each time it runs:

DBOS.logger.info(f"I just ran at {scheduled_time}")

You can view your application's logs from your applications page.

Deploy with GitHub

Next Steps

You can adapt this 6-line starter to implement your own scheduled job. Replace scheduled_function with your own function to run it on a schedule! Some useful implementation notes:

  • Schedules are specified in crontab syntax. For example, * * * * * means "run once a minute." To learn more about crontab syntax, see this guide.
  • The two arguments passed into scheduled_function are the time the run was scheduled (as a datetime) and the time the run was actually started (as a datetime).
  • For more information, see the scheduling documentation.

Here are two larger examples built with DBOS scheduling:

  • Hacker News Slackbot: Periodically search Hacker News for people commenting about serverless computing and post the comments to Slack.
  • Earthquake Tracker: Use a scheduled job to scrape earthquake data from the USGS, then build a real-time earthquake dashboard over it.

Running It Locally

You can also run your application locally for development and testing.

1. Git Clone Your Application

Clone your application from git and enter its directory.

git clone <your-git-url>
cd dbos-cron-starter

2. Set up a virtual environment

Create a virtual environment and install dependencies.

python3 -m venv .venv
source .venv/bin/activate
pip install -r requirements.txt

3. Start Your Appliation

dbos start