Back to Datahub

Dbt Cloud Pre

metadata-ingestion/docs/sources/dbt/dbt-cloud_pre.md

1.5.0.32.0 KB
Original Source

Overview

The dbt-cloud module ingests metadata from Dbt into DataHub. It is intended for production ingestion workflows and module-specific capabilities are documented below.

Prerequisites

Before running ingestion, ensure network connectivity to the source, valid authentication credentials, and read permissions for metadata APIs required by this module.

Setup

Extracts dbt metadata from dbt Cloud APIs.

Create a service account token with "Metadata Only" permission (read-only).

Operating Modes

The dbt Cloud source supports two modes of operation:

1. Explicit Mode (Default)

Specify a single dbt Cloud job to ingest metadata from. The job must have "Generate docs on run" enabled and should process all/most models (otherwise multiple job ingestion may be required).

To get the required IDs, go to the job details page (this is the one with the "Run History" table), and look at the URL. It should look something like this: https://cloud.getdbt.com/next/deploy/107298/projects/175705/jobs/148094. In this example, the account ID is 107298, the project ID is 175705, and the job ID is 148094.

2. Auto-Discovery Mode

Automatically discovers and ingests metadata from all eligible jobs in a dbt Cloud project. This mode:

  • Discovers all jobs in the specified project's production environment only
  • Filters to jobs with "Generate docs on run" enabled (generate_docs=True)
  • Always uses the latest run for each job (ignores run_id configuration)
  • Supports optional regex-based filtering to include/exclude specific job IDs
  • Ingests metadata from multiple jobs in a single run

When to use auto-discovery:

  • You have multiple dbt Cloud jobs in a project and want to ingest all of them
  • You want to automatically pick up new jobs without updating configuration

Requirements:

  • Jobs must be in the production environment
  • Jobs must have "Generate docs on run" enabled