A CLI tool to monitor individual dbt Cloud run jobs and receive Slack or OS notifications when they complete.
Developers working with large dbt projects and merge queues often wait for long-running CI jobs. This tool solves two problems:
- Manual Monitoring: Instead of repeatedly checking job status or working on other things and forgetting about your dbt job and holding up the merge queue, automatically get notified when your specific run job completes.
- Notification Control: AFAIK, dbt Cloud does not have notifications for job-specific runs. You can get notifications for all jobs of a specific environment/deployment, but not for specific runs within those environment/deployment jobs (i.e your own CI jobs in a staging environment).
- Python >= 3.8
uv
(Python package manager)- dbt Cloud account with API access (via the dbt developer PAT)
- Environment variables:
DBT_CLOUD_ACCOUNT_ID
DBT_CLOUD_API_KEY
SLACK_WEBHOOK_URL
- Only needed if posting notifications to Slack (need a valid Slack App with an authorized webhook URL)
- Default behavior of
dh
is to post to OS notifications
NOTE: While uv
is the recommended method for installing dbt-heartbeat
, you can also install it using pip install
. However, when installing with pip
, you are responsible for managing your Python virtual environment and ensuring that the directory containing the executable is included in your system's PATH
. In contrast, when using uv
no additional environment configuration is required, and the executable is automatically made available in your PATH
for immediate use.
brew install uv
uv tool install dbt-heartbeat
- Add environment variables to your
.zshrc
shell configuration file:# Paste in your .zshrc file (Mac: /Users/<user_name>/.zshrc) export DBT_CLOUD_ACCOUNT_ID=<dbt_cloud_account_id> export DBT_CLOUD_API_KEY=<dbt_cloud_pat> export SLACK_WEBHOOK_URL=<webhook_url>
- Run
dh <run_job_id> --slack
# Check for latest version
dh --version
# Upgrade to the latest version
uv tool upgrade dbt-heartbeat
For help:
dh --help
job_run_id
: The ID of the dbt Cloud job run to monitor-
--slack
or-s
: Send notifications to Slack (requires SLACK_WEBHOOK_URL environment variable)
--poll-interval
: Time in seconds between polls (default: 30)--log-level
: Set the logging level (default: INFO)- Choices: DEBUG, INFO, WARNING, ERROR, CRITICAL
--version
: Checks for the latest version and prints the current version
# Poll run job with default settings and send notification to system OS
dh 123456
# Poll run job with default settings and send notification to Slack
dh 123456 --slack
# Poll run job with debug logging and 15-second interval and send notification to Slack
dh 123456 --s --log-level DEBUG --poll-interval 15
Note: You can find the <job_run_id>
in the dbt Cloud UI:
- In the job run details page, look for
Run #<job_run_id>
in the header of each run - Or from the URL when viewing a job run:
https://cloud.getdbt.com/deploy/<account_id>/projects/<project_id>/runs/<job_run_id>

