A Python-based application to backup Grafana settings using the Grafana API
Project description
Grafana Backup Tool
A Python-based application to backup Grafana settings using the Grafana API.
The aim of this tool is to:
- Easily backup and restore Grafana.
- Have versioned backups
(date and time in file name)
for restoring and saving to cloud storage providers likeAmazon S3
orAzure Storage
.
Supported components
- Folder
- Dashboard (contains Alert)
- Datasource
- Alert Channel
- Organization (Needs Basic Authentication (username and password, see grafana doc)
- You need to set
Admin's account and password
ingrafanaSettings.json
, or set the base64 encodedadmin account and password
in ENVGRAFANA_BASIC_AUTH
. E.gexport GRAFANA_BASIC_AUTH=YWRtaW46YWRtaW4=
- Or Sets this ENV of the Grafana server
GF_USERS_ALLOW_ORG_CREATE=true
. see grafana doc
- You need to set
- User (Needs Basic Authentication (username and password, see grafana doc)
- You need to set
Admin's account and password
ingrafanaSettings.json
, or set the base64 encodedadmin account and password
in ENVGRAFANA_BASIC_AUTH
. E.gexport GRAFANA_BASIC_AUTH=YWRtaW46YWRtaW4=
- Grafana's api doesn't provide user's password when backing up, so the
default_password (which is in the grafanaSetting.json)
will be used when restoring.
- You need to set
Requirements
- Bash
- Python 2.7 or Python 3.x
- Access to a Grafana API server.
- A
Token
of anAdmin
role (seeConfiguration
section below for more info)
Configuration
There are three ways to setup the configuration:
- Use
environment variables
to define the variables for connecting to a Grafana server. - Use
hard-coded settings
inconf/grafanaSettings.json
(this is the default settings file if not specified otherwise). - Use
~/.grafana-backup.json
to define variables in json format.
Example Config
- Check out the examples folder for more configuration details
NOTE If you use environment variables
, you need to add the following to your .bashrc
or execute once before using the tool (please change variables according to your setup):
(GRAFANA_HEADERS
is optional, use it if necessary. please see #45)
### Do not use a trailing slash on GRAFANA_URL
export GRAFANA_URL=http://some.host.org:3000
export GRAFANA_TOKEN=eyJrIjoidUhaU2ZQQndrWFN3RRVkUnVfrT56a1JoaG9KWFFObEgiLCJuIjoiYWRtaW4iLCJpZCI6MX0=
# GRAFANA_HEADERS is optional
export GRAFANA_HEADERS=Host:some.host.org
To create and obtain a Token
for your Grafana server, please refer to the official documentation.
NOTE that you need to generate a Token
with an Admin
role for the backup to succeed, otherwise you will have potential permission issues.
Installation
Virtual environment (optional but recommended)
Create a virtualenv, you could using something like pyenv
if you'd prefer
virtualenv -p $(which python3) venv
source venv/bin/activate
Installation using pypi
pip install grafana-backup
Installation using this repo
First clone this repo
git clone https://github.com/ysde/grafana-backup-tool.git
cd grafana-backup-tool
Installation works best using pip
pip install .
How to Use
- First perform the Configuration and Installation sections as described above.
- Use the
grafana-backup save
command to backup all your folders, dashboards, datasources and alert channels to the_OUTPUT_
subdirectory of the current directory.
Example:
$ grafana-backup save
$ tree _OUTPUT_
_OUTPUT_/
└── 202006272027.tar.gz
- Use the
grafana-backup restore <archive_file>
command with a path to a previous backup to restore everything.
NOTE this may result in data loss, by overwriting data on the server.
Example:
$ grafana-backup restore _OUTPUT_/202006272027.tar.gz
Docker
Replace variables below to use the Docker version of this tool
{YOUR_GRAFANA_TOKEN}
: Your Grafana siteToken
.{YOUR_GRAFANA_URL}
: Your Grafana siteURL
.{YOUR_BACKUP_FOLDER_ON_THE_HOST}
: Thebackup folder
on the Grafana host machine.
Backup
If you decide to use a volume (-v) then you'll need to create the volume first with 1337 uid/gid ownership first, example:
mkdir /tmp/backup
sudo chown 1337:1337 /tmp/backup
docker run --rm --name grafana-backup-tool \
-e GRAFANA_TOKEN={YOUR_GRAFANA_TOKEN} \
-e GRAFANA_URL={YOUR_GRAFANA_URL} \
-e VERIFY_SSL={True/False} \
-e AWS_S3_BUCKET_NAME={OPTIONALLY_UPLOAD_TO_S3_BUCKET} \
-e AWS_S3_BUCKET_KEY={YOUR_S3_BUCKET_KEY} \
-e AWS_DEFAULT_REGION={YOUR_AWS_REGION} \
-e AWS_ACCESS_KEY_ID={YOUR_AWS_ACCESS_KEY_ID} \
-e AWS_SECRET_ACCESS_KEY={YOUR_AWS_SECRET_ACCESS_KEY} \
-v {YOUR_BACKUP_FOLDER_ON_THE_HOST}:/opt/grafana-backup-tool/_OUTPUT_ \
alpinebased:grafana-backup
Example:
docker run --rm --name grafana-backup-tool \
-e GRAFANA_TOKEN="eyJrIjoiNGZqTDEyeXNaY0RsMXNhbkNTSnlKN2M3bE1VeHdqVTEiLCJuIjoiZ3JhZmFuYS1iYWNrdXAiLCJpZCI6MX0=" \
-e GRAFANA_URL=http://192.168.0.79:3000 \
-e VERIFY_SSL=False \
-e AWS_S3_BUCKET_NAME="my-backups-bucket" \
-e AWS_S3_BUCKET_KEY="grafana-backup-folder" \
-e AWS_DEFAULT_REGION="us-east-1" \
-e AWS_ACCESS_KEY_ID="secret" \
-e AWS_SECRET_ACCESS_KEY="secret" \
-v /tmp/backup/:/opt/grafana-backup-tool/_OUTPUT_ \
alpinebased:grafana-backup
Restore
docker run --rm --name grafana-backup-tool \
-e GRAFANA_TOKEN={YOUR_GRAFANA_TOKEN} \
-e GRAFANA_URL={YOUR_GRAFANA_URL} \
-e VERIFY_SSL={True/False} \
-e RESTORE="true" \
-e ARCHIVE_FILE={THE_ARCHIVED_FILE_NAME} \
-v {YOUR_BACKUP_FOLDER_ON_THE_HOST}:/opt/grafana-backup-tool/_OUTPUT_ \
alpinebased:grafana-backup
Example:
docker run --rm --name grafana-backup-tool \
-e GRAFANA_TOKEN="eyJrIjoiNGZqTDEyeXNaY0RsMXNhbkNTSnlKN2M3bE1VeHdqVTEiLCJuIjoiZ3JhZmFuYS1iYWNrdXAiLCJpZCI6MX0=" \
-e GRAFANA_URL=http://192.168.0.79:3000 \
-e VERIFY_SSL=False \
-e RESTORE="true" \
-e ARCHIVE_FILE="202006280247.tar.gz" \
-v /tmp/backup/:/opt/grafana-backup-tool/_OUTPUT_ \
alpinebased:grafana-backup
Building
You can build the docker image simply by executing make
in the root of this repo. The image will get tagged as alpinebased:grafana-backup
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for grafana_backup-1.1.3-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 47724463b18d93a1354466cac878c4273fa798e32bdb4f41aa53ba980c85b719 |
|
MD5 | c1ad6935c21bdac158aa61f10eeefd69 |
|
BLAKE2b-256 | 7ee57c697b61471ee52b4417d789d93bdc4032725b26e5ae5ac4b7b5c2754561 |