This project uses Tinybird's Service Data Sources to aggregate and publish organizational metrics as endpoints in Prometheus format for quick integration with common monitoring tools.
- Includes a set of Pipes that consolidate and process organizational metrics.
- Exposes all key metrics through a single Pipe Endpoint in Prometheus format for streamlined monitoring.
- Provides essential insights to help you monitor your usage, detect anomalies, and set up alerts in critical areas such as:
- Data ingestion: Track the volume and frequency of ingested data.
- Pipe endpoint usage: Analyze requests and identify unusual traffic patterns.
- Storage: Monitor storage usage to optimize resources and avoid limits.
- Jobs: Keep track of the status and performance of scheduled jobs.
- You must have a Tinybird organization.
- You need to be an admin of the organization to access organization Service Data Sources.
To deploy this template on Tinybird, click the following button:
Access the Prometheus metrics endpoint at https://api.tinybird.co/v0/pipes/organization_metrics.prometheus
.
- Replace
api.tinybird.co
with your Tinybird host if the workspace is in a different region. See Regions and endpoints. - Token: for a quick check in development, you can use the pre-existing admin
user@domain
Token of an Organization admin to authenticate requests. But for production, the creation of a new token with less permissions is recommended, including these scopes:
PIPES:READ:organization_metrics
ORG_DATASOURCES:READ
- As of this writing, the
ORG_DATASOURCES:READ
is not available from UI, but you can create this new prometheus_org_access token using tokens API like this:
POST https://api.tinybird.co/v0/tokens/?name=prometheus_org_access&description=optional&scope=PIPES:READ:organization_metrics&scope=ORG_DATASOURCES:READ
To scrape the Tinybird metrics endpoint, you can configure your prometheus.yml
file as follows:
scrape_configs:
- job_name: tinybird_org_metrics
scrape_interval: 15s # Adjust the scrape interval as needed
scheme: 'https'
static_configs:
- targets:
- 'api.tinybird.co' # Adjust this for your region if necessary
metrics_path: '/v0/pipes/organization_metrics.prometheus'
bearer_token: '<admin-user-token>' # From an Organization admin
If you use a different setup, such as Datadog and OpenMetrics, you can use the following configuration:
instances:
- prometheus_url: https://api.tinybird.co/v0/pipes/organization_metrics.prometheus?token=<admin-user-token>
namespace: tinybird
metrics:
- "*"
tags:
- tinybird
max_returned_metrics: 10000 # Adjust this value as needed
Remember to replace api.tinybird.co
with your Tinybird host if the Workspace is in a different region. See Regions and endpoints.
We've included a sample dashboard config for Grafana to help you get started. See the JSON file.
Import the dashboard with the following steps:
- Go to Grafana and click on the Dashboards menu.
- Select New > Import.
- Click on Upload dashboard JSON file.
- Select the JSON file and select Upload.
- Select the Prometheus datasource.
- Click Import.
The dashboard uses the Prometheus configuration in this repo, with the job name tinybird_org_metrics
.
Add the following configuration to your OpenMetrics Datadog agent conf.yaml
file:
instances:
- prometheus_url: 'https://api.tinybird.co/v0/pipes/organization_metrics.prometheus?token=<admin-user-token>'
namespace: tinybird_org_metrics
metrics:
- "*"
max_returned_metrics: 700000
- Replace
api.tinybird.co
with your Tinybird host if the workspace is in a different region. See Regions and endpoints. - Use the
user@domain
admin token of an Organization admin to authenticate requests.
We've included a sample dashboard config for Datadog that you can use to get started. See the JSON file.
Import the dashboard with the following steps:
- Go to Datadog and click on the Dashboards menu.
- Select New Dashboard.
- Select New Dashboard in the dialog.
- Select the settings gear icon (⚙️).
- Select Import Dashboard.
- Browse to the JSON file.
- Select Yes, replace.