Skip to main content

Dagster & Bash / Shell

Dagster comes with a native PipesSubprocessClient resource that enables you to launch shell commands directly from Dagster assets and ops. This integration allows you to pass parameters to external shell scripts while Dagster receives real-time events, such as logs, asset checks, and asset materializations, from the initiated external execution. With minimal code changes required on the job side, this integration is both efficient and easy to implement.

Installation

pip install dagster

Example

import shutil

import dagster as dg


@dg.asset
def shell_asset(
context: dg.AssetExecutionContext, pipes_subprocess_client: dg.PipesSubprocessClient
):
shell_script_path = "/path/to/your/script.sh"
return pipes_subprocess_client.run(
command=["bash", shell_script_path],
context=context,
).get_results()


defs = dg.Definitions(
assets=[shell_asset],
resources={"pipes_subprocess_client": dg.PipesSubprocessClient()},
)

About shell

A shell is a computer program that presents a command line interface which allows you to control your computer using commands entered with a keyboard instead of controlling graphical user interfaces with a mouse/keyboard/touchscreen combination.