Writes data from fritzbox to influxdb
"fritzinfluxdb" is a tool written in python to fetch data from a FritzBox router and writes it to InfluxDB. It is equal capable as fritzcollectd and directly writing to InfluxDB.
Data collected:
Both InfluxDB 1 and InfluxDB 2 are supported
In order work properly you need to enable "permit access for applications" and "state data via UPnP"
It was tested using FritzOS 7.29. It should work on older versions but some values might be missing.
DSL and Cable Modem FritzBox versions are supported. During startup there are messages about disabled services. This is normal as there are values not available on certain models.
/opt
After cloning the repo copy the config from the example
to fritzinfluxdb.ini
and edit the settings. All settings are described inside the file.
Config values can also be overwritten using environment variables.
schema: <SECTION_NAME>_<CONFIG_OPTION> (all in capital letters)
example for InfluxDB token:
export INFLUXDB_TOKEN="abcedef"
Environment variables will overwrite options defined in config file.
sudo apt-get install python3-virtualenv
cd /opt
git clone https://github.com/bb-Ricardo/fritzinfluxdb.git
cd fritzinfluxdb
virtualenv -p python3 .venv
. .venv/bin/activate
pip3 install -r requirements.txt
yum install git python36-virtualenv
cd /opt
git clone https://github.com/bb-Ricardo/fritzinfluxdb.git
cd fritzinfluxdb
virtualenv-3 .venv
. .venv/bin/activate
pip3 install -r requirements.txt
dnf install git-core python3-virtualenv
cd /opt
git clone https://github.com/bb-Ricardo/fritzinfluxdb.git
cd fritzinfluxdb
virtualenv-3 .venv
. .venv/bin/activate
pip3 install -r requirements.txt
dnf install git-core
cd /opt
git clone https://github.com/bb-Ricardo/fritzinfluxdb.git
cd fritzinfluxdb
python3 -m venv .venv
. .venv/bin/activate
pip3 install -r requirements.txt
./fritzinfluxdb.py
Ubuntu
cp /opt/fritzinfluxdb/fritzinfluxdb.service /etc/systemd/system
RHEL/CentOS/Rocky/Alma
sed -e 's/nogroup/nobody/g' /opt/fritzinfluxdb/fritzinfluxdb.service > /etc/systemd/system/fritzinfluxdb.service
systemctl daemon-reload
systemctl start fritzinfluxdb
systemctl enable fritzinfluxdb
Run the application in a docker container. You can build it yourself or use the ones from docker hub.
Available here: bbricardo/fritzinfluxdb
/app
To build it by yourself just run:
docker build -t bbricardo/fritzinfluxdb:latest .
To start the container just use:
docker run --rm -d -v /PATH/TO/fritzinfluxdb.ini:/app/fritzinfluxdb.ini --name fritzinfluxdb bbricardo/fritzinfluxdb:latest
You can alternatively use the provided docker-compose.yml:
docker-compose up -d
If you're running the influxdb in a docker on the same host you need to add --link
to the run command.
docker run --name=influxdb -d -p 8086:8086 influxdb
fritzinfluxdb.ini
to influxdb
docker run --link influxdb -d -v /PATH/TO/fritzinfluxdb.ini:/app/fritzinfluxdb.ini --name fritzinfluxdb fritzinfluxdb
pip3 install -r requirements.txt
To create an InfluxDB 1 database or InfluxDB 2 Bucket (incl. retention policy mapping) it is recommended to use admin credentials/token on the first run. DON'T use an admin token after initial setup has finished.
InfluxDB 1 example:
export INFLUXDB_USERNAME=admin
export INFLUXDB_PASSWORD=SuperSecret
InfluxDB 2 example:
export INFLUXDB_TOKEN=InfluxDBAdminToken
If running via docker this
link describes how to set env vars on a docker run
For InfluxDB 2 it is highly recommended creating a specific write only token for the defined bucket.
usage: fritzinfluxdb.py [-h] [-c fritzinfluxdb.ini [fritzinfluxdb.ini ...]] [-d] [-v]
fritzinfluxdb
Version: 1.2.1 (2023-01-26)
Project URL: https://github.com/bb-Ricardo/fritzinfluxdb
optional arguments:
-h, --help show this help message and exit
-c fritzinfluxdb.ini [fritzinfluxdb.ini ...], --config fritzinfluxdb.ini [fritzinfluxdb.ini ...]
points to the config file to read config data from which is not installed under the default path './fritzinfluxdb.ini'
-d, --daemon define if the script is run as a systemd daemon
-v, --verbose turn on verbose output to get debug logging. Defining '-vv' will also print out all http calls
Dashboards to display the collected data are included under grafana. Due to some limitations of the InfluxDB 1.8 Flux language implementation the dashboards had to bes separated.
Influx data source configuration:
InfluxDB 1.8:
InfluxQL
has to be selectedInfluxDB >=2.2.0:
Flux
has to be selectedThere are following Dashboards included:
InfluxDB 1.8.X (deprecated):
InfluxDB >=2.2.0:
This was heavily inspired by: https://grafana.com/dashboards/713
check here to find an overview of more attributes which probably could be added https://wiki.fhem.de/w/index.php?title=FRITZBOX
New services can be defined in fritzinfluxdb/classes/fritzbox/service_definitions
You can check out the full license here
This project is licensed under the terms of the MIT license.