Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/dj-nitehawk/hybrid-inverter-monitor
Monitoring application for hybrid inverters using the Voltronic communication protocol & JK BMS via USB port.
https://github.com/dj-nitehawk/hybrid-inverter-monitor
axpert easun effekta epever jk-bms jkbms mpp-solar mppsolar pip-inverter sako voltronic voltronic-axpert-inverters
Last synced: 5 days ago
JSON representation
Monitoring application for hybrid inverters using the Voltronic communication protocol & JK BMS via USB port.
- Host: GitHub
- URL: https://github.com/dj-nitehawk/hybrid-inverter-monitor
- Owner: dj-nitehawk
- License: mit
- Created: 2022-06-27T02:47:55.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2024-12-24T16:17:36.000Z (18 days ago)
- Last Synced: 2024-12-30T15:17:19.467Z (12 days ago)
- Topics: axpert, easun, effekta, epever, jk-bms, jkbms, mpp-solar, mppsolar, pip-inverter, sako, voltronic, voltronic-axpert-inverters
- Language: C#
- Homepage:
- Size: 2.39 MB
- Stars: 91
- Watchers: 10
- Forks: 22
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Hybrid Inverter Monitor
---
This application allows you to monitor chinese hybrid inverters such as `MPPSolar, Epever, Must,, Easun, Voltronic Axpert, etc.` in realtime via USB/Serial port as an alternative to the wifi module and cloud based apps such as SmartESS, Watchpower, Smartclient, etc. which can be at times unreliable.
For this to work, you need to connect a linux computer such as a raspberry/orange pi or any other linux computer to the inverter via USB/Serial cable. Windows will not work due to the non-existence of a working device driver.
Once your inverter is connected via a data cable, a new device path should appear either in `/dev/hidrawX` or `/dev/ttyUSBX`. Once that's available and if your inverter supports the **Voltronic** communication protocol, all you have to do is execute the `InverterMon.Server` executable. The binaries can be downloaded from the [releases section](https://github.com/dj-nitehawk/Hybrid-Inverter-Monitor/releases). Make sure to choose the correct architecture (x64/arm) for your machine.
After the application has started successfully, you can simply open up a web browser and navigate to `http://ip.address.of.machine` to see the dashboard. It may take up to 5 seconds for the data to show up initially.
If you have a firewall, please open port `80` to facilitate communication.
In order to make the application/server automatically start at boot, follow the below procedure to create a `systemd` service.
# Auto Start Configuration Steps
open the following file (or the correct one for your OS):
`sudo nano /lib/udev/rules.d/99-systemd.rules`
add the following text to the end:
```
KERNEL=="ttyUSB1", SYMLINK="ttyUSB1", TAG+="systemd"
```if your device is mounted as a **hidraw** device, change the value above to `hidrawX`.
create a new file for the service
`sudo nano /etc/systemd/system/invertermon.service`
copy/paste the following:
```ini
[Unit]
Description=Hybrid Inverter Monitor#change here if device is hidraw
After=dev-ttyUSB1.device[Service]
Type=simple
User=root
Group=root
UMask=000#put the downloaded files in here
WorkingDirectory=/inverter
ExecStart=/inverter/InverterMon.ServerRestart=always
RestartSec=30[Install]
WantedBy=multi-user.target
```
run the following commands to enable and start the service:
```
sudo systemctl enable invertermon
sudo systemctl start invertermon
sudo systemctl status invertermon
```
restart the machine to check if the service was configured correctly.# JK BMS Support
If you have a JK BMS + JK RS485 adapter + USB->TTL adapter, simply wire them up correctly and plug it in to the computer.
The app will try to connect to the BMS via serial port by default at address `/dev/ttyUSB0`.
If your USB->TTL device is mounted at a different device path, simply update the `appsettings.json` file with the correct path like so:
```json
{
"LaunchSettings": {
"JkBmsAddress": "/dev/ttyUSB1"
}
}
```