Skip to content

Python Script which exports Kostal Inverter Data into a PostgreSQL and Influx Database

License

Notifications You must be signed in to change notification settings

zerinthiadevops/kostal-dataexporter

 
 

Repository files navigation

Kostal Piko Dataexporter

This Python scripts grabs content of the REST API of a Kostal PIKO 7.0 and exports the data either to PostgreSQL Database, InfluxDB v1 or InfluxDB v2).

Setup

  • PostgreSQL: Import the init.sql into your Database
  • InfluxDB: Create Database (eg pv)
  • Set environment variables with the relevant details
  • KOSTAL_USERNAME
  • KOSTAL_PASSWORD
  • KOSTAL_HOST
  • For PostgreSQL:
    • DB_HOST
    • DB_PORT
    • DB_NAME
    • DB_USER
    • DB_PASSWORD
  • For InfluxDB (1.x):
    • INFLUXDB_HOST
    • INFLUXDB_PORT
    • INFLUXDB_NAME
    • INFLUXDB_USER
    • INFLUXDB_PASSWORD
  • For InfluxDB (2.x):
    • INFLUXDB_ORG
    • INFLUXDB_BUCKET
    • INFLUXDB_URL
    • INFLUXDB_TOKEN
  • Run python kostal-piko-dataexport.py
    • --influx 1 (on, optional) or --influx 0 (off, optional)
    • --influx2 1 (on, default) or --influx 0 (off, optional)
    • --postgres 1 (on, optional) or --postgres 0 (off, default)
    • --interval {seconds} Scrape interval (default: 30)
    • --oneshot Scrape data, print to stdout and exit

There's also a Docker Image available on GitLab's project Container Registry.

Grafana

By logging the data with this script it's easily possible to create a nice Grafana Dashboard to display some of the interesting data:

My dashboard on a sunny day in Germany

You can import the dashboard-postgresql.json for PostgreSQL, dashboard-influx.json for influxdb v1 or dashboard-influxdb2.json to use it in your Grafana instance.

Note

This is just a quick-and-dirty script to grab to content of the REST-API of my Kostal Piko 7.0 Inverter. This might be usable on other Inverters aswell.

About

Python Script which exports Kostal Inverter Data into a PostgreSQL and Influx Database

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 96.9%
  • Dockerfile 3.1%