- Documentation
- Learning Hub
- Dashboards as Code with the Foundation SDK
- CI/CD automation
Reliable, repeatable deployments
How Terraform handles existing dashboards
A reliable pipeline produces the same result no matter how many times you run it, with no duplicate dashboards and no errors. Terraform ensures this with a state file: a record of the resources it has created. On each run, Terraform decides what to change by comparing three things:
- Your configuration
- The state file
- What actually exists in Grafana
When the live dashboard no longer matches your code (for example, someone edited it in the UI), that difference is called drift. Because of this, you can safely retry failed runs and merge to main repeatedly without creating duplicates.
Why stable UIDs matter
A stable UID in your DashboardBuilder gives Terraform a consistent identifier to track across runs. With it, Terraform updates the same dashboard each time. Without it, Terraform has nothing to match against, so each deployment creates a new dashboard and you get duplicates on every run.
builder := dashboard.NewDashboardBuilder("My Dashboard").
Uid("my-dashboard") // Same UID = update, not duplicate