Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/infertux/growatt_exporter
Prometheus (Grafana) / MQTT (Home Assistant) exporter for Growatt solar inverters
https://github.com/infertux/growatt_exporter
grafana growatt home-assistant mqtt prometheus-exporter solar spf5000es
Last synced: 2 months ago
JSON representation
Prometheus (Grafana) / MQTT (Home Assistant) exporter for Growatt solar inverters
- Host: GitHub
- URL: https://github.com/infertux/growatt_exporter
- Owner: infertux
- License: other
- Created: 2023-01-31T12:13:43.000Z (almost 2 years ago)
- Default Branch: master
- Last Pushed: 2024-06-28T06:21:44.000Z (6 months ago)
- Last Synced: 2024-06-29T06:54:03.092Z (6 months ago)
- Topics: grafana, growatt, home-assistant, mqtt, prometheus-exporter, solar, spf5000es
- Language: C
- Homepage:
- Size: 711 KB
- Stars: 4
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
README
# growatt_exporter
growatt_exporter is a standalone program written in C that can query [Growatt](https://www.growattenergy.com/) solar inverters and output metrics compatible with Prometheus, Grafana, MQTT and Home Assistant.
This allows to monitor PV production, battery status, etc. on a nice Grafana interface.This has been tested extensively on the [SPF 5000 ES](https://www.growattenergy.com/product/growatt-spf-5000-es-off-grid/) but should work with any product offering a RS485 interface.
## Screenshots
![PV Production](doc/pv-production.png)
![Inverter Output](doc/inverter-output.png)
![Home Assistant](doc/home-assistant.png)The complete list of sensors can be found in [growatt.h](src/growatt.h).
## Build
### From source
```bash
apt install clang libbsd-dev libconfig-dev libmodbus-dev libmosquitto-dev mosquitto-clients
make
```### Using Docker
```bash
./docker-build.sh
```## Install
1. Install runtime dependencies:
`apt install libconfig9 libmodbus5 libmosquitto1`
2. Copy binary:
`cp growatt_exporter /opt/growatt-exporter`
3. Create config file `/etc/growatt-exporter.conf`:
```
device_or_uri = "/dev/ttyUSB0"prometheus = {
port = 1234
}mqtt = {
host = "10.0.0.1"
port = 1883
username = "homeassistant"
password = "foobar"
}
```4. Create systemd service file `/etc/systemd/system/growatt-exporter.service`:
```systemd
[Unit]
After=network.target[Service]
ExecStart=/opt/growatt-exporter /etc/growatt-exporter.conf
Restart=on-failure
RestartSec=10
PrivateTmp=true
ProtectHome=true
ProtectProc=invisible
ProtectSystem=full[Install]
WantedBy=multi-user.target
```5. Enable and start systemd service:
`systemctl enable --now growatt-exporter`
## Kudos
The "Growatt OffGrid SPF5000 Modbus RS485 RTU Protocol" PDF document has been a very valuable resource. A copy of it is included in this Git repository. Thank you to the original author for their work.
## Other brands
Would like to monitor Epever/Epsolar Tracer solar charge controllers instead? Here is a sister repository for that: https://github.com/infertux/epever_exporter
## Other approaches
- Blog post: https://www.splitbrain.org/blog/2023-11/03-growatt_and_home_assistant
- Reading Modbus registers via Home Assistant: https://github.com/home-assistant/core/issues/94149
- https://github.com/rspring/Esphome-Growatt## License
AGPLv3+