Schedule a flow
Deploy flows and run them on a schedule with Prefect.
In the Quickstart, you learned how to convert a Python script to a Prefect flow.
In this tutorial, you’ll learn how to get that flow off of your local machine and run it on a schedule with Prefect.
Publish your code to a remote repository
First, you need to take the code from your local machine and publish it to a remote repository. We’ve already published the code to GitHub that you need for this tutorial:
Create a work pool
Running a flow locally is a good start, but most use cases require a remote execution environment. A work pool is the most common interface for deploying flows to remote infrastructure.
Deploy your flow to a self-hosted Prefect server instance using a Process
work pool.
All flow runs submitted to this work pool will run in a local subprocess (the creation mechanics are similar for other work pool types that run on remote infrastructure).
-
Create a
Process
work pool: -
Verify that the work pool exists:
-
Start a worker to poll the work pool:
You can also choose from other work pool types.
Deploy and schedule your flow
A deployment is used to determine when, where, and how a flow should run. Deployments elevate flows to remotely configurable entities that have their own API. To set a flow to run on a schedule, you need to create a deployment.
-
Create a deployment in code:
create_deployment.pyYou can store your flow code in nearly any location as long as Prefect can access it. See Where to store your flow code for more details.
-
Run the script to create the deployment:
Check the logs to ensure your deployment was created:
-
Schedule a run for the deployment:
Soon you should see the flow run graph and logs on the Flow Run page in the UI. Logs are also streamed to the terminal.
Next steps
In this tutorial, you successfully deployed your flow to remote infrastructure and scheduled it to run automatically.
Next, learn how to build a resilient and performant data pipeline with retries, concurrent tasks, concurrency limits, and caching.
Need help? Book a meeting with a Prefect Product Advocate to get your questions answered.