Welcome to Week 2 of the Data Engineering Zoomcamp! This week, we'll cover workflow orchestration with Kestra.
Kestra is an open-source, event-driven orchestration platform that makes both scheduled and event-driven workflows easy. By bringing Infrastructure as Code best practices to data, process, and microservice orchestration, you can build reliable workflows directly from the UI in just a few lines of YAML.
The course will cover the basics of workflow orchestration, why it's important, and how it can be used to build data engineering pipelines.
In this section, we'll cover the basics of workflow orchestration. We'll discuss what it is, why it's important, and how it can be used to build data pipelines.
Videos
- 2.2.1 - Introduction to Workflow Orchestration
Resources
In this section, you'll learn what is Kestra, how to use it, and how to build a Hello-World data pipeline.
Videos
- 2.2.2 - Learn the Concepts of Kestra
Resources
In this section, we'll cover how you can ingest the Yellow Taxi data from the NYC Taxi and Limousine Commission (TLC) and load it into a Postgres database. We'll cover how to extract data from CSV files, and load them into a local Postgres database running in a Docker container.
Note
The TLC Trip Record Data provided on the nyc.gov website is currently available only in a Parquet format, but this is NOT the dataset we're going to use in this course. For the purpose of this course, we'll use the CSV files available here on GitHub. This is because the Parquet format can be challenging to understand by newcomers, and we want to make the course as accessible as possible — the CSV format can be easily introspected using tools like Excel or Google Sheets, or even a simple text editor.
Videos
- 2.2.3 - Create a ETL Pipeline with Postgres in Kestra
So far, you've explored how to run ETL locally using Postgres, we'll do the same on GCP. We'll load the same data to:
- Data lake using Google Cloud Storage (GCS)
- Data Warehouse using BigQuery.
Videos
- 2.2.4 - Create a ETL Pipeline with GCS and BigQuery in Kestra
In this section, we'll cover how you can schedule your data pipelines to run at specific times. We'll also cover how you can backfill your data pipelines to run on historical data.
We'll demonstrate backfills first locally using Postgres and then on GCP using GCS and BigQuery.
Videos
- 2.2.5 - Manage Scheduling and Backfills using Postgres in Kestra
- 2.2.6 - Manage Scheduling and Backfills using BiqQuery in Kestra
In this section, we'll cover how you can transform your tables using dbt inside of your Kestra Flow.
Videos
- 2.2.7 - Transform Data with dbt and Postgres in Kestra
- 2.2.8 - Transform Data with dbt and BigQuery in Kestra
In this section, we'll cover how you can install Kestra on Google Cloud in Production, and automatically sync and deploy your workflows.
Videos
- 2.2.9 - Deploy Workflows to the Cloud with Git
Resources
- Install Kestra on Google Cloud
- Moving from Development to Production
- Using Git in Kestra
- Deploy Flows with GitHub Actions
The homework for this week can be found here. Don't worry, it's just a bunch of Multiple Choice Questions to test your understanding of Kestra, Workflow Orchestration, and ETL pipelines for a data lake and data warehouse.
- Check Kestra Docs
- Explore our Blueprints library
- Browse over 600 plugins available in Kestra
- Give us a star on GitHub
- Join our Slack community if you have any questions
- Find all the videos in this YouTube Playlist
If you encounter similar errors to:
BigQueryError{reason=invalid, location=null,
message=Error while reading table: kestra-sandbox.zooomcamp.yellow_tripdata_2020_01,
error message: CSV table references column position 17, but line contains only 14 columns.;
line_number: 2103925 byte_offset_to_start_of_line: 194863028
column_index: 17 column_name: "congestion_surcharge" column_type: NUMERIC
File: gs://anna-geller/yellow_tripdata_2020-01.csv}
It means that the CSV file you're trying to load into BigQuery has a mismatch in the number of columns between the external source table (i.e. file in GCS) and the destination table in BigQuery. This can happen when for due to network/transfer issues, the file is not fully downloaded from GitHub or not correctly uploaded to GCS. The error suggests schema issues but that's not the case. Simply rerun the entire execution including redownloading the CSV file and reuploading it to GCS. This should resolve the issue.
Did you take notes? You can share them here. Just create a PR to this file and add your notes below.