 How-to Guides
How-to Guides
Learn Kestra with our hands-on guides.
Adjust the filters based on your needs or search directly.
Access Files on your Local Machine in Kestra
Access locally stored files on your machine inside Kestra workflows.
Configure Alerts inside of Kestra
Configure alerts when workflow failures occurs.
Extend Kestra with the API
Extend Kestra by using the API.
Use Azure Managed Workload on Kestra
How to use Azure Workload identity to provide access to resources such as Azure Key Vault in Kestra
Configure Local Ceph Storage for Kestra via MinIO Gateway
This guide demonstrates how to deploy a local Ceph cluster using cephadm and expose a S3-compatible endpoint (Rados Gateway). MinIO will act as a gateway to Ceph, and Kestra will continue to use MinIO as its object storage.
Use Cloudflare R2 with MinIO Gateway for Kestra
This guide demonstrates how to use Cloudflare R2 as an object storage backend through an S3-compatible interface, exposed to Kestra via a MinIO Gateway. This setup enables Kestra to continue using S3 storage without requiring configuration changes.
Conditional Branching
How to use the Switch task to branch the flow based on a value.
Build a Custom Plugin for Kestra
Build your own Custom Plugin for Kestra.
Using Dataform in Kestra
Run transformations on BigQuery using Dataform in Kestra
Manage dbt projects with Kestra's Code Editor
Edit dbt code from Kestra's Code Editor
Debezium Tasks and Triggers
How to enable databases to leverage Debezium tasks and triggers.
Dynamic Flows
Implement dynamic flows in Kestra.
Dynamic Dropdown for Inputs
Support dynamic dropdown for inputs based on data from external source.
ETL Pipelines in Kestra
Build ETL pipelines in Kestra using DuckDB, Python and Task Runners.
Validate and Deploy your Flows with GitHub Actions
How to use GitHub Actions to automatically validate and deploy your flows to Kestra.
Run Go inside of your Flows
Run Go code directly inside of your Flows and generate outputs.
Configure Google Service Account
Setup a Google Service Account inside of Kestra.
Connect Google Sheets to Kestra
Learn step-by-step how to read data from a Google Sheet inside of a Kestra flow.
Make HTTP Requests inside of your flows
Make HTTP Requests to fetch data and generate outputs.
Pass Inputs via an API call
Passing Inputs via an API Call
Validate Inputs with Enum Data Type
Input validation with the Enum data type
Run JavaScript inside of your Flows
Run Node.js code directly inside of your Flows and generate outputs.
Connect Web Apps to Kestra
Integrate Kestra into your JavaScript App using Webhooks.
Interacting with JSONs in Kestra
Interact with JSONs using expressions.
Run Julia inside of your Flows
Run Julia code directly inside of your Flows and generate outputs.
Configure KeyCloak SSO in Kestra
Setup KeyCloak SSO to manage authentication for users.
Set Up Secrets from a Helm Chart
How to add Kestra Secrets to your Helm Chart deployment.
Local Flow Synchronization
Sync Flows from a local directory.
Long running and intensive processes on Kubernetes
Schedule long running and intensive processes with Kestra on Kubernetes.
Loop Over a List of Values
How to iterate over a list of values in your flow.
Configure Local MinIO Storage for Kestra
Set up and verify a local MinIO storage backend for Kestra using the mc CLI and Docker.
Configure Monitoring with Grafana & Prometheus
Set up Prometheus and Grafana for monitoring Kestra.
Multiple Condition Listener
How to set up a Flow to only trigger when multiple conditions are met.
Namespace Variables vs KV Store
When to store key-value pairs as namespace-level Variables vs. KV store
Connect Neon Database to Kestra
Connect your Neon serverless database to your workflows using the PostgreSQL plugin.
Notion Webhook Integration
Use Notion webhooks to trigger Kestra flows when pages or databases are updated in your Notion workspace.
Handling null and undefined values
How to use the null coalescing operator to handle null and undefined values.
Parallel vs. Sequential Tasks
When to use parallel tasks and when to use sequential tasks in Kestra.
Pause and Resume Flows in Kestra
How to Pause and Resume your flows.
Run Perl inside of your Flows
Run Perl code directly inside of your Flows and generate outputs.
Run Powershell inside of your Flows
Run PowerShell code inside of your flow.
Trigger a Flow on a Prometheus Alert
Connect Prometheus alerts to Kestra to trigger flows.
Push Flows to a Git Repository
Push your Flows to a Git Repository with the PushFlows Task.
Push Namespace Files to a Git Repository
Push files in your namespace to a Git Repository with the PushNamespaceFiles Task.
Run Python inside of your Flows
Run Python code directly inside of your Flows and generate outputs.
Manage Python Dependencies
Manage your Python dependencies inside of Kestra.
Manage Python Dependencies with uv
Manage your Python Dependecies inside of Kestra using uv.
Run R inside of your Flows
Run R code directly inside of your Flows and generate outputs.
Realtime Triggers
How to React to events as they happen with millisecond latency.
Revision History & Rollback
Use revision history to rollback to an older version of a flow.
Run Ruby inside of your Flow
Run Ruby code directly inside of your Flows and generate outputs.
Run Rust inside of your Flows
Run Rust code directly inside of your Flows and generate outputs.
Configure Secrets
Learn how to securely configure and use secrets in Kestra.
Run Shell scripts inside of your Flows
Run Shell scripts directly inside of your Flows and generate outputs.
Migrate from Shipyard
Migrate from Shipyard to Kestra.
Slack Events API
Trigger Kestra flows based on Slack events.
Using SQLMesh to run dbt Projects
Using SQLMesh to run dbt project with Kestra.
Connect Supabase Database to Kestra
Connect your Supabase Database to your workflows using the PostgreSQL plugin.
Sync Flows from a Git Repository
Sync flows from a Git Repository to Kestra with the SyncFlows Task.
Synchronous Executions API
Manage the Executions API Synchronously.
Sync Namespace Files from a Git Repository
Sync files from a Git Repository to Kestra with SyncNamespaceFiles Task.
Modularize your triggers and schedules with Terraform
Scale your codebase using Terraform to template and make scheduling a breeze
Leverage Terraform for flow modularity
Scale your codebase using Terraform to template and define flows
Access Values Between Flows
How to access values across different flows.
Setup Webhooks to trigger Flows
Execute flows using the Webhooks Trigger.
Was this page helpful?
