npx claudepluginhub grafana/gcx --plugin gcxThis skill uses the workspace's default tool permissions.
This skill teaches agents to configure gcx for a Grafana instance,
Guides Grafana OSS features: building dashboards, configuring panels and data sources, provisioning YAML, template variables, alerting, RBAC, users, and PromQL/LogQL/TraceQL queries.
Query and manage Grafana dashboards, alert rules, and data sources via HTTP API. Useful for viewing dashboards, troubleshooting alerts, checking metrics, or on mentions of Grafana, monitoring, observability.
Share bugs, ideas, or general feedback.
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.
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
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.
Use this path when connecting to a Grafana Cloud instance
(URLs ending in .grafana.net).
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.
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.
gcx config use-context cloud
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.
Use this path when connecting to a self-hosted Grafana instance.
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).
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.
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.
gcx config use-context onprem
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>
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) |
- 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.
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_CONFIG environment variable$XDG_CONFIG_HOME/gcx/config.yaml$HOME/.config/gcx/config.yaml$XDG_CONFIG_DIRS/gcx/config.yamlTo avoid passing -d <uid> on every query command, configure default
datasource UIDs for the active context.
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 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.
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
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.net URLs) or set grafana.stack-id explicitly.grafana.org-id to the numeric org ID (usually 1).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.
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).
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 true
Use insecure-skip-verify only for development; supply a CA certificate in
production environments instead.
gcx resolves the API namespace (Kubernetes namespace for all calls) in this order:
/bootdata HTTP call to the serverorg-id is non-zero: use org-<id> namespaceorg-id is zero: use configured stack-idIf 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
# 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
For a complete listing of all config set paths, environment variables,
namespace resolution logic, and multi-context patterns, see
references/configuration.md.