Cloudfoundry buildpack to deploy Grafana 9 and get it automatically configured. This buildpack is able to automatically setup a database from a service broker instance (both mysql and postgres are supported) if no database connection is provided it will use a sqlite database.
When you can skip having a proper DB (mysql or postgres):
- If a single grafana instance is enough for your use case.
- If you do not care about user management
- If all dashboards and datasources are defined in configuration files.
With points 2 and 3 potentially you would have skip 1'st point and have multiple instances, but this setup is not tested.
Having mysql or postgres, this buildpack allows you to deploy multiple instances because sessions are stored there.
This buildpack is focused on CloudSQL offered by Google Service Broker. It "should" support other service broker instances, but we have not checked it (PR are welcome!)
In order to test new versions of the buildpack, please use dev
branch and
merge with master only when you are sure it works, otherwise it would cause
a lot of pain to other users of this buildpack.
First of all, this buildpack has no requirements at all, in order to get Grafana working,
you can create app folder, put a manifest.yml
like this in your root folder:
---
applications:
- name: grafana
memory: 512M
instances: 1
stack: cflinuxfs4
random-route: true
buildpacks:
- https://github.com/SpringerPE/cf-grafana-buildpack.git
env:
ADMIN_USER: admin
ADMIN_PASS: admin
SECRET_KEY: yUeEBtX7eTmh2ixzz0oHsNyyxYmebSat
and run from the root folder cf push
Aditionally by binding the app to a SQL instance (mysql or postgres), everything will be saved in a persistent DB, but this is not really recommented unless you are testing or you want to become a good developer/devops (you know replicable builds, traceable changes, etc)
To use this buildpack, specify the URI of this repository when push to Cloud Foundry.
$ cf push <APP-NAME> -b https://github.com/SpringerPE/cf-grafana-buildpack.git
If you want to deploy a specific version, have a look at the git tags available
and put a #
removing the .git
extension like this:
$ cf push <APP-NAME> -b https://github.com/SpringerPE/cf-grafana-buildpack#<TAG>
For example:
$ cf push <APP-NAME> -b https://github.com/SpringerPE/cf-grafana-buildpack#v1
or define it in the manifest.yml
:
---
applications:
- name: grafana
buildpack: https://github.com/SpringerPE/cf-grafana-buildpack#v1
First have a look at the official documentation of Grafana: http://docs.grafana.org/installation/configuration/
This buildpack is highly flexible, these are some keypoints to match the official documentation with this buildpack implementation.
- The app folder is the
provisioning
folder specified in the documentation, so you can create these directories:datasources
,dashboards
,notifiers
there as the official documenation says. - The default configuration refereed as
defaults.ini
is provided and customized for the buildpack: https://github.com/SpringerPE/cf-grafana-buildpack/blob/master/defaults.ini - The custom configuration file referred as
custom.ini
will be applied automatically by placing a file namedgrafana.ini
in the root folder of the app, socustom.ini
is calledgrafana.ini
. - You can use all environment variables to setup Grafana (
GF_*
), except the ones in the[paths]
section of the configuration file. - Plugins folder points to
plugins
in the root app, so all plugins will be installed there automatically.
Apart of the Grafana environment variables, you can define these ones:
- DEFAULT_DATASOURCE_EDITABLE (default
false
). By default the auto-generated datasources for Prometheus and Alertmanager are not editable. Changing this value makes then editable, but if you do not use a DB be aware that changes on their properties will be lost after redeploy grafana. - DEFAULT_DATASOURCE_TIMEINTERVAL (default
60s
). Lowest interval/step value that should be used for default generated data source. - HOME_DASHBOARD_UID (default
home
). Used to setup automatically the Grafana home dashboard (the one users see automatically when they log in). If you provision a dashboard withuid
equal toHOME_DASHBOARD_UID
, the buildpack will setup such dashboard as home. Theuid
is part of the url of each dashboard, and it can be defined to a string likehome
(by default is a random generated string) to give some meaning to the dashboard urls. More info: https://grafana.com/docs/http_api/dashboard/#identifier-id-vs-unique-identifier-uid. - ADMIN_USER: main admin user (default is
admin
) - ADMIN_PASS: admin password (defautl is
admin
) - SECRET_KEY: Used for signing some datasource settings like secrets and passwords. Cannot be changed without requiring an update to datasource settings to re-encode them. Because this variable is so important, if it is not defined, it defaults to the space uuid where the app is running.
- DOMAIN: uri of the application, defauls to the first route in CF.
- EMAIL: when a smtp is configured this is the
from
field, defaults tografana@$DOMAIN
. - DB_BINDING_NAME: name of the binding with a service instance to use as SQL database. By default is empty, so the builpack will search for bindings providing a DB connection string in their
credentials.uri
field. If it is defined it will skip automatic search and focus only on the provided one. - URL: URL of the app, defaults to
http://$DOMAIN
. If using https you will need to redefine this variable (specially for Oauth integrations!).
For production use, define a proper ADMIN_PASS
and SECRET_KEY
. The rest of variables should
be good with their defautls.
When using a named service broker instance, you can define MAIN_DB_BINDING_NAME
, otherwise is not needed if the app is bound to only a SQL instance used for everything (sessions, resources, cache)
If you want to use your own Grafana settings, just place a grafana.ini
file in the
app folder with your settings. This is useful to define oauth
settings and get users
automatically defined in Grafana. Have a look to the official documentation.
Grafana version can be specified in a file runtime.txt
. Lines starting
with #
are ignored, otherwise it will install the version defined in the buildpack
(check parameters.sh
), example:
# Define your grafana version here
9.3.1
This buildpack only supports Grafana 7.x or greater!
You can also define which plugins will be automatically installed in a file plugins.txt
:
# Define your plugins here. Format is 2 columns: pluginid version
# https://grafana.com/plugins
satellogic-3d-globe-panel 0.1.0
As an alternative you can uncompress a plugin in a plugins
folder or use locally grafana-cli
specifiying pluginsDir
to plugins
: grafana-cli --pluginsDir plugins plugins install <id> <version>
As said, you can use a service broker instance which exposes a SQL connection string
in .credentials.uri
, the DB connection string has to be properly formed and only
using mysql
or postgres
.
If you do not have a service broker implementation, you can still use it via user provided services:
$ cf create-user-provided-service mysql-db -p '{"uri":"mysql://root:[email protected]:3306/mydatabase"}'
# bind a service instance to the application
$ cf bind-service <app name> <service name>
# restart the application so the new service is detected
$ cf restart
This buildpack is primary made to work with GCP Service Broker. Grafana does not support TLS connection strings for all DBs (e.g. session SQL DB), the way to overcome to this situation was using a Cloud SQL Proxy: https://github.com/GoogleCloudPlatform/cloudsql-proxy
When the builpack detects a GCP Service broker, it automatically runs the cloud-sql proxy
and change all Grafana connection settings to point to localhost. The SQL proxy connects
to the DB server using the TLS settings and PrivateData
auth.
For example, to define Oauth auth with Google, just create a file grafana.ini
like this:
[auth.google]
enabled = true
client_id = "${CLIENT_ID}"
client_secret = "${CLIENT_SECRET}"
scopes = https://www.googleapis.com/auth/userinfo.profile https://www.googleapis.com/auth/userinfo.email
auth_url = https://accounts.google.com/o/oauth2/auth
token_url = https://accounts.google.com/o/oauth2/token
allowed_domains = companydomain1.com companydomain2.com
allow_sign_up = true
In the CF manifest, you can define the variables needed:
---
applications:
- name: mission-control
memory: 512M
instances: 1
stack: cflinuxfs4
buildpack: https://github.com/SpringerPE/cf-grafana-buildpack.git
env:
CLIENT_ID: 'blabla'
CLIENT_SECRET: 'blabla'
URL: https://mygrafana.companydomain.com
Do not forget to define $URL
with the https protocol!.
In order to test new versions of the buildpack, use docker-compose build && docker-compose up
Please use a different branch and merge with master only when you are sure it works, otherwise it would cause
a lot of pain to other users of this buildpack.
Implemented using bash scripts to make it easy to understand and change.
https://docs.cloudfoundry.org/buildpacks/understand-buildpacks.html
The builpack uses the deps
and cache
folders according the implementation purposes,
so, the first time the buildpack is used it will download all resources, next times
it will use the cached resources.
Copyright © Springer Nature
MIT License