Prefect Concepts

Scheduled jobs and managing tasks with Prefect

Prefect is an open source workflow orchestration tool made for data-intensive workloads. This allows you to schedule and organize jobs to run any time, in your chosen order. It can accommodate dependencies between jobs, and is very useful for data pipelines and machine learning workflows.

Saturn Cloud supports two different tools in the Prefect ecosystem:

  • Prefect Core, which is an open source library users can install, and
  • Prefect Cloud, which is a fully hosted cloud service. The same team that maintains the prefect core library runs Prefect Cloud. Prefect Cloud is a hosted, high-availability, fault-tolerant service that handles all the orchestration responsibilities for running data pipelines.

For a more in-depth discussion of these concepts, visit the Prefect Core documentation. They definitely have the best information about their tools!

If you are familiar with Apache Airflow, you might best understand Prefect through comparisons to that project. See “Why not Airflow” in the Prefect documentation for more.

Tasks

A Task represents a discrete action in a Prefect workflow. This is easy to conceptualize as a function - it’s a standalone chunk of work to be done. This chunk of work might accept inputs and it might produce outputs.

An Example Task

from prefect import task

@task
def add(x, y=1):
    return x + y

Flows

A “flow” is a container for multiple tasks which understands the relationship between those tasks. Tasks are arranged in a directed acyclic graph (DAG), which just means that there is always a notion of which tasks depend on which other tasks, and those dependencies are never circular.

When you are creating a Prefect flow, you’re developing a set of tasks, then instructing Prefect on when they should be run, and in what order. Prefect also offers flexible control over what to do when a specific task or entire flow fails.

An Example Flow

from prefect import Flow, task

@task
def add(x, y=1):
    return x + y

with Flow("My first flow") as flow:
    first_result = add(1, y=2)
    second_result = add(x=first_result, y=100)

Running a Flow

Running a flow is as simple as running flow.run() after your flow is defined.

At this point, you have the basic concepts behind Prefect! Now, you might want to see some more complex examples, so go visit our Prefect tutorials to learn more.


Need help, or have more questions? Contact us at:

We'll be happy to help you and answer your questions!