grafana/pkg/services/apiserver
2024-02-16 17:07:37 +02:00
..
aggregator K8s: Set X-Remote- headers for SignedInUser (#82543) 2024-02-15 12:29:36 -05:00
auth K8s: Pass ID token in X-Extra-id-token header (#82893) 2024-02-16 17:07:37 +02:00
builder K8s: Update common openapi generation scripts (#81857) 2024-02-04 22:37:10 +02:00
endpoints K8s: Add Aggregation to Backend Service (#81591) 2024-02-12 22:59:35 +02:00
options APIServer: Use options pattern in standalone mode (#82760) 2024-02-15 12:00:20 -08:00
registry/generic K8s: Refactor config/options for aggregation (#81739) 2024-02-01 17:27:30 -05:00
rest K8s: Refactor config/options for aggregation (#81739) 2024-02-01 17:27:30 -05:00
standalone APIServer: Use options pattern in standalone mode (#82760) 2024-02-15 12:00:20 -08:00
storage K8s: Add Aggregation to Backend Service (#81591) 2024-02-12 22:59:35 +02:00
utils K8s: Refactor config/options for aggregation (#81739) 2024-02-01 17:27:30 -05:00
config.go K8s: Add Aggregation to Backend Service (#81591) 2024-02-12 22:59:35 +02:00
README.md K8s: Add Aggregation to Backend Service (#81591) 2024-02-12 22:59:35 +02:00
service.go K8s: Set X-Remote- headers for SignedInUser (#82543) 2024-02-15 12:29:36 -05:00
wireset.go K8s: Refactor config/options for aggregation (#81739) 2024-02-01 17:27:30 -05:00

Grafana Kubernetes compatible API Server

Basic Setup

[feature_toggles]
kubernetesPlaylists = true

Start Grafana:

make run

Enable dual write to etcd

Start etcd:

make devenv sources=etcd

Set storage type and etcd server address in custom.ini:

[grafana-apiserver]
storage_type = etcd
etcd_servers = 127.0.0.1:2379

Enable dual write to JSON files:

Set storage type:

[grafana-apiserver]
storage_type = file

Objects will be written to disk under the {data.path}/grafana-apiserver/ directory.

For example:

data/grafana-apiserver
├── grafana.kubeconfig
└── playlist.grafana.app
    └── playlists
        └── default
            └── hi.json

Enable aggregation

See aggregator/README.md for more information.

kubectl access

For kubectl to work, grafana needs to run over https. To simplify development, you can use:

app_mode = development

[feature_toggles]
grafanaAPIServerEnsureKubectlAccess = true 
kubernetesPlaylists = true

This will create a development kubeconfig and start a parallel ssl listener. It can be registered by navigating to the root grafana folder, then running:

export KUBECONFIG=$PWD/data/grafana-apiserver/grafana.kubeconfig
kubectl api-resources

Grafana API Access

The Kubernetes compatible API can be accessed using existing Grafana AuthN at: http://localhost:3000/apis.

The equivalent openapi docs can be seen in http://localhost:3000/swagger, select the relevant API from the dropdown in the upper right.