Sample Setup
Grafana In Kubernetes
In this demonstration we will use the Agilicus Connector to securely, simply expose a Grafana service running inside a Kubernetes cluster.
Overview
In this demonstration we will use the Agilicus Connector to securely, simply expose a Grafana service running inside a Kubernetes cluster.
This will work for clusters that have no Ingress, no LoadBalancer, no public IP. It will allow you to add any user, from any identity provider, with a simple single-sign-on. If you push alerts via a Chat channel, you can just click on the link to get to the graph, no VPN.
First, install the Agilicus Connector in your Kubernetes cluster.
Second, create the Grafana Application in the Admin web interface.
data:image/s3,"s3://crabby-images/f862d/f862d54f6548eca378d75dcba25f693c7fa58b0e" alt="Sample Grafana In Kubernetes 2 2efb2e52 image"
The application name will become the hostname (e.g. here we will have https://grafana.MYDOMAIN)
data:image/s3,"s3://crabby-images/f347a/f347a3ee3ec8d5ec40b832794ab89ac766c9e2c4" alt="Sample Grafana In Kubernetes 3 c0fd0742 image"
You may use a pattern-based name (APPNAME.MYDOMAIN), or, a specific hostname (e.g. my-grafana).
data:image/s3,"s3://crabby-images/3af41/3af41e297a4b675033abb1fb170e463f3de3f06e" alt="Sample Grafana In Kubernetes 4 7660800f image"
Here we will use the Kubernetes Connector we created earlier.
data:image/s3,"s3://crabby-images/a16af/a16af27ab3fe0eef69d6b079e3398f30ed46dc5f" alt="Sample Grafana In Kubernetes 5 6cc3dfbd image"
For this demonstration we use TLS from user to the connector in your Kubernetes cluster. If there is a desire for fine-grained audit, use the other option.
data:image/s3,"s3://crabby-images/6d02b/6d02b265d9e0cf8d99999773488cc3ff1d248093" alt="Sample Grafana In Kubernetes 6 852b3630 image"
The hostname will be with respect to CoreDNS in your cluster. In this case, we have installed grafana in the ‘grafana’ namespace, so it is http://grafana.grafana:3000
data:image/s3,"s3://crabby-images/b516b/b516b166f8692b6d9695b42e29e1bedcc5ee5424" alt="Sample Grafana In Kubernetes 7 2efc8319 image"
We select ‘authenticated by proxy’. In this case, no traffic will hit Grafana except for authenticated, authorised users.
data:image/s3,"s3://crabby-images/dbf94/dbf94f6dadcc48d485e72d0955e06e43a63cc124" alt="Sample Grafana In Kubernetes 8 27b38869 image"
You may choose to allow everyone access, or create specific groups.
data:image/s3,"s3://crabby-images/851db/851dbb391fb54769922719310decc3a1442ec2eb" alt="Sample Grafana In Kubernetes 9 97faa0a1 image"
We are now complete. Hit APPLY, and wait 2-3 minutes, then enter https://grafana.MYDOMAIN in your browser.
data:image/s3,"s3://crabby-images/cefac/cefac35d255950ffe6b8b59ae51b1d8dfa2a77ab" alt="Sample Grafana In Kubernetes 10 6b689de1 image"
Auto-Sign-In, Auto-User-Create (Optional)
The authenticating proxy sets various headers in a trusted fashion. These include:
Remote_org_id: <GUID>
Remote_user: <email>
Remote_user_id: <GUID>
X-Gateway-Org: <GUID>
X-Gateway-Primary-Role: <role name>
X-Gateway-Roles: <map appname: array role name>
X-Gateway-Tokenid: <GUID>
X-Gateway-User: <GUID>
X-Gateway-User-Email: <email>
In Grafana, in its config, this section can be configured. if so, the end-user will auto-login (create on first use) with no provisioning.
[auth.proxy]
enabled = true
header_name = Remote_user
header_property = username
auto_sign_up = true