setup-gcx
Setup gcx
This skill teaches agents to configure gcx for a Grafana instance, covering the three configuration paths (Grafana Cloud, on-premise, and environment variables) and resolving common setup errors.
Step 0: Install gcx
First, check whether gcx is already installed:
gcx --version
If the command is not found, build it from source. Requires git and Go v1.24+:
tmp=$(mktemp -d) && git clone --depth 1 https://github.com/grafana/gcx.git "$tmp" && (cd "$tmp" && go install ./cmd/gcx) && rm -rf "$tmp"
After installing, verify the binary is on PATH:
gcx --version
Configuration Model
gcx uses a context-based configuration model inspired by kubectl's
kubeconfig. A single YAML file (default: ~/.config/gcx/config.yaml)
stores named contexts. Each context points to one Grafana instance and holds
the server URL, authentication credentials, and namespace identifiers. One
context is active at a time; all commands operate against it unless overridden.
Use gcx config view to inspect the current configuration at any time.
Use gcx config check to validate that the active context is correct
and can reach the server.
Path A: Grafana Cloud
Use this path when connecting to a Grafana Cloud instance
(URLs ending in .grafana.net).
Step 1: Create a context
gcx config set contexts.cloud.grafana.server https://myorg.grafana.net
Replace cloud with any name you prefer for this context (e.g., prod,
myorg-cloud). Replace the server URL with your Grafana Cloud URL.
Step 2: Set the API token
gcx config set contexts.cloud.grafana.token glsa_XXXXXXXXXXXXXXXX
Obtain a service account token from Administration > Service accounts in your Grafana Cloud instance. The token must have sufficient permissions for the operations you intend to run (Viewer for read-only, Editor or Admin for write operations).
The grafana.token field takes precedence over grafana.user/grafana.password
when both are present.
Step 3: Switch to the context
gcx config use-context cloud
Step 4: Verify the connection
gcx config check
A successful check prints the active context name and server URL without
errors. For Grafana Cloud, the stack ID (namespace) is auto-discovered from
the server's /bootdata endpoint -- you do not need to set grafana.stack-id
manually unless auto-discovery fails.
Namespace note: gcx maps Grafana Cloud instances to a Kubernetes
namespace of the form stacks-<id>. This namespace is discovered automatically
by calling the /bootdata endpoint on the server URL. If the discovered stack
ID conflicts with a manually configured grafana.stack-id, gcx raises a
validation error. To resolve: either remove the manually configured stack ID
(gcx config unset contexts.cloud.grafana.stack-id) or correct it to
match the discovered value.
Path B: On-Premise Grafana
Use this path when connecting to a self-hosted Grafana instance.
Step 1: Create a context
gcx config set contexts.onprem.grafana.server https://grafana.example.com
Replace onprem with a name that identifies this environment (e.g.,
production, staging, local).
Step 2: Set authentication
Option B-1: API token (recommended)
gcx config set contexts.onprem.grafana.token glsa_XXXXXXXXXXXXXXXX
Option B-2: Username and password
gcx config set contexts.onprem.grafana.user admin
gcx config set contexts.onprem.grafana.password mysecretpassword
Use Option B-1 when service accounts are available. Use Option B-2 for development or when service accounts are not configured.
Step 3: Set the org ID
On-premise Grafana uses an org ID to identify the namespace for API calls. Set it to the numeric ID of the organization (default org is 1):
gcx config set contexts.onprem.grafana.org-id 1
To find the org ID: in Grafana, go to Administration > Organizations and note the numeric ID shown in the URL when you select an org.
Step 4: Switch to the context
gcx config use-context onprem
Step 5: Verify the connection
gcx config check
TLS options (optional): If your Grafana instance uses a self-signed certificate or a custom CA, configure TLS:
# Skip TLS verification (development only -- do not use in production)
gcx config set contexts.onprem.grafana.tls.insecure-skip-verify true
# Supply a custom CA certificate (base64-encoded PEM)
gcx config set contexts.onprem.grafana.tls.ca-data <base64-encoded-pem>
Path C: Environment Variables (CI/CD)
Use this path when gcx runs in a CI/CD pipeline or another automated environment where writing a config file is impractical. Environment variables override the active context's fields at runtime without modifying the config file.
| Environment Variable | Overrides Field | Description |
|---|---|---|
GRAFANA_SERVER |
grafana.server |
Server URL |
GRAFANA_TOKEN |
grafana.token |
API token (takes precedence over user/pass) |
GRAFANA_USER |
grafana.user |
Username for basic auth |
GRAFANA_PASSWORD |
grafana.password |
Password for basic auth |
GRAFANA_ORG_ID |
grafana.org-id |
Org ID (on-premise namespace) |
GRAFANA_STACK_ID |
grafana.stack-id |
Stack ID (Grafana Cloud namespace) |
Example: GitHub Actions
- name: Run gcx
env:
GRAFANA_SERVER: ${{ secrets.GRAFANA_SERVER }}
GRAFANA_TOKEN: ${{ secrets.GRAFANA_TOKEN }}
GRAFANA_ORG_ID: "1"
run: gcx resources get dashboards -o json
Environment variables apply to the current context only and do not modify the config file on disk.
Config file location
If you need to supply a config file path explicitly:
gcx --config /path/to/config.yaml resources get dashboards
# or
export GCX_CONFIG=/path/to/config.yaml
Config file search order (highest to lowest priority):
--config <path>CLI flag$GCX_CONFIGenvironment variable$XDG_CONFIG_HOME/gcx/config.yaml$HOME/.config/gcx/config.yaml$XDG_CONFIG_DIRS/gcx/config.yaml
Default Datasource Configuration
To avoid passing -d <uid> on every query command, configure default
datasource UIDs for the active context.
Find your datasource UIDs
gcx datasources list -o json
Locate the uid field for each datasource. Example output:
{
"datasources": [
{ "uid": "prometheus-uid-abc123", "name": "Prometheus", "type": "prometheus" },
{ "uid": "loki-uid-def456", "name": "Loki", "type": "loki" }
]
}
Set defaults
# Set the default Prometheus datasource
gcx config set contexts.cloud.default-prometheus-datasource prometheus-uid-abc123
# Set the default Loki datasource
gcx config set contexts.cloud.default-loki-datasource loki-uid-def456
Replace cloud with your context name and the UID values with those from the
output above. After setting these, query commands that support a -d flag will
use the configured defaults automatically.
Multi-Context Management
To work with multiple Grafana environments, create a context for each:
# Create contexts
gcx config set contexts.production.grafana.server https://grafana.example.com
gcx config set contexts.production.grafana.token glsa_PROD_TOKEN
gcx config set contexts.production.grafana.org-id 1
gcx config set contexts.staging.grafana.server https://grafana-staging.example.com
gcx config set contexts.staging.grafana.token glsa_STAGING_TOKEN
gcx config set contexts.staging.grafana.org-id 1
# Switch between contexts
gcx config use-context production
gcx config use-context staging
# Use a context for a single command without switching
gcx --context staging resources get dashboards
To list all configured contexts, view the full config:
gcx config view
Secrets (token, password) are redacted in this output. To see raw values:
gcx config view --raw
Troubleshooting
config check fails
Run gcx config check to diagnose configuration problems. It prints the
active context and performs a live health check against the server.
If it reports a missing server or empty context:
# Verify current context is set
gcx config view
# Ensure the current-context field is not empty
gcx config set current-context <your-context-name>
If it reports a missing namespace (stack ID or org ID):
- Grafana Cloud: either let auto-discovery resolve it (no manual action
needed for
.grafana.netURLs) or setgrafana.stack-idexplicitly. - On-premise: set
grafana.org-idto the numeric org ID (usually1).
401 Unauthorized
The token or credentials are invalid or expired.
# Replace with a fresh token
gcx config set contexts.<name>.grafana.token glsa_NEW_TOKEN
Verify the token has not expired and has the correct permissions for the operations you intend to run.
403 Forbidden
The token is valid but lacks permissions for the requested operation. In Grafana, navigate to Administration > Service accounts, select the service account, and assign an appropriate role (Viewer, Editor, or Admin).
Connection refused or timeout
The server URL is unreachable.
-
Confirm the URL is correct:
gcx config view -
Test connectivity from the machine running gcx:
curl -I https://grafana.example.com/api/health -
Check for proxy requirements or VPN. If the instance uses a self-signed certificate:
gcx config set contexts.<name>.grafana.tls.insecure-skip-verify trueUse
insecure-skip-verifyonly for development; supply a CA certificate in production environments instead.
Namespace resolution issues
gcx resolves the API namespace (Kubernetes namespace for all calls) in this order:
- Attempt auto-discovery via
/bootdataHTTP call to the server - If discovery fails and
org-idis non-zero: useorg-<id>namespace - If discovery fails and
org-idis zero: use configuredstack-id
If you see a "mismatched stack ID" error, a configured grafana.stack-id
differs from the auto-discovered value. Resolve by unsetting the manual value:
gcx config unset contexts.<name>.grafana.stack-id
If you see a "missing namespace" error and auto-discovery is failing (e.g.,
the server does not expose /bootdata), set the namespace manually:
# On-premise
gcx config set contexts.<name>.grafana.org-id 1
# Grafana Cloud (if auto-discovery is unavailable)
gcx config set contexts.<name>.grafana.stack-id 12345
Complete Example: Grafana Cloud Setup
# 1. Set server and token
gcx config set contexts.mycloud.grafana.server https://myorg.grafana.net
gcx config set contexts.mycloud.grafana.token glsa_XXXXXXXXXXXXXXXX
# 2. Activate the context
gcx config use-context mycloud
# 3. Verify
gcx config check
# 4. Set default datasources (after listing available ones)
gcx datasources list -o json
gcx config set contexts.mycloud.default-prometheus-datasource <prometheus-uid>
gcx config set contexts.mycloud.default-loki-datasource <loki-uid>
# 5. Test a resource listing
gcx resources get dashboards -o json
Reference
For a complete listing of all config set paths, environment variables,
namespace resolution logic, and multi-context patterns, see
references/configuration.md.
More from grafana/gcx
gcx
>
5explore-datasources
Discover what datasources, metrics, labels, and log streams are available in a Grafana instance. Use when the user asks what data exists, what metrics are available, what services are being monitored, or needs to find a datasource UID.
4gcx-observability
>
3slo-check-status
Use when the user asks about SLO health, wants an overview of all SLOs, or needs status of a specific SLO. Trigger on phrases like "how are my SLOs doing", "SLO status", "check my SLOs", "is my SLO healthy", "SLO budget", "SLO burn rate". For investigating breaching SLOs use slo-investigate. For optimization suggestions use slo-optimize. For creating or modifying SLO definitions use slo-manage.
2slo-investigate
Use when a specific SLO is breaching or alerting and the user needs to understand why — root cause analysis, dimensional breakdown, alert rule correlation, runbook access. Trigger on phrases like "investigate SLO", "why is my SLO breaching", "SLO error budget burning", "SLO alerting". For SLO status overview use slo-check-status. For creating or modifying SLOs use slo-manage. For optimization suggestions use slo-optimize.
2import-dashboards
>
2