NEWS
[Linux Shell-Skript] WLAN-Wetterstation
-
@Rushmed, das ist sehr erfreulich!
@Rushmed sagte in [Linux Shell-Skript] WLAN-Wetterstation:
Ist es normal dass Werte der Datenpunkte im Object view nicht bestätigt werden un daher rot bleiben?
Ja bei mir auch
@Rushmed sagte in [Linux Shell-Skript] WLAN-Wetterstation:
Ich habe sowohl in WS View als auch in der Scriptconfig 16 s Pollzeit eingestellt, bekomme die Werte aber stets alle 32 s.
Ist nicht tragisch aber ich hätte Aktualisierung alle 16 s erwartet.Ist mir auch schon aufgefallen, unter 30 s geht nichts
Die verwendbaren Wetterdienste aus WS View bekommen die Daten alle 60 s übermittelt - da haben wir zumindest einen Vorteil -
@Latzi sagte in [Linux Shell-Skript] WLAN-Wetterstation:
Ist mir auch schon aufgefallen, unter 30 s geht nichts
Die verwendbaren Wetterdienste aus WS View bekommen die Daten alle 60 s übermittelt - da haben wir zumindest einen Vorteil
Ja und vor allem ist der Weg der Daten viel kürzer und die Protokollierung ausfallsicherer. -
@Rushmed sagte in [Linux Shell-Skript] WLAN-Wetterstation:
Ja und vor allem ist der Weg der Daten viel kürzer und die Protokollierung ausfallsicherer.
ABSOLUT !!!
-
@Rushmed sagte in [Linux Shell-Skript] WLAN-Wetterstation:
Ist es normal dass Werte der Datenpunkte im Object view nicht bestätigt werden un daher rot bleiben?
Ja. Der Simple-RESTful-Adapter kann beim Bulk-Update kein Ack=true setzen, dass geht nur beim Schreiben einzelner Datenpunkte. 15 Werte schreiben mit Sicherheitsverzögerung = 20 Sekunden ... nicht gerade prickelnd.
@Rushmed sagte in [Linux Shell-Skript] WLAN-Wetterstation:
Ist nicht tragisch aber ich hätte Aktualisierung alle 16 s erwartet.
Ich ehrlich gesagt auch. Anscheinend kann man zwar 16 Sekunden einstellen, sie schickt aber wohl nur im 30 Sekundentakt. Ich ziehe vom Poll-Intervall 5 Sekunden ab = das Skript macht 11 Sekunden gar nix, dann startet der "nc" und wartet auf ein Datenpaket welches nun nach 5 Sekunden eintrudeln müsste.
Könnt es mal auf 16 Sekunden stehen lassen, Skript stoppen (pkill -9 wetterstation.*), nc mittels nc -lv xxxx (xxxx=Port) starten. Wenn ein Paket angekommen ist Sekundenanzeige auf der Uhr merken, sofort nc wieder starten --> kommt nächstes Paket nun nach ~ 16 oder 30 Sekunden? -
-
@Rushmed Na supi
Dann ist es wie ich es mir schon dachte. Im 30 Sekunden-Takt genügt ja auch (Batterielebensdauer), aber trotzdem blöd, dass man dann in der APP auch bis zu 16 Sekunden runter stellen kann. Ich ändere dann mal das Mindestintervall auf 30 Sekunden ab. -
Sagt mal was ist denn jetzt die schlauste Art meine Wetterdaten zu loggen wenn ich die immer am Jahresende in Excel aufbereiten will?
Mit dem History Adapter sehe ich da noch keinen Weg. -
@Rushmed
ich verwende den Datenexport von weathercloud, komprimiere je Tag und je Monat und erstelle so die Jahres/Monats/Tagesstatistiken und Verläufe -
@SBorg sagte in [Linux Shell-Skript] WLAN-Wetterstation:
Eine Möglichkeit wäre, wenn es bspw. immer um 23:59, 0:00 oder 0:01 auftritt (also regelmäßig), dass Skript anzuhalten und neu zu starten:
crontab -e
unter "@reboot /home/iobroker/wetterstation.sh &" noch eine weiteren cronjob anfügen:
2 0 * * * pkill -9 wetterstation.* && /home/iobroker/wetterstation.sh &
(wieder darauf achten, dass noch eine Leerzeile folgt!)
speichern --> fertig
also etwa so:> @reboot /home/iobroker/wetterstation.sh & > 2 0 * * * pkill -9 wetterstation.* && /home/iobroker/wetterstation.sh &
/home/iobroker natürlich anpassen, 2 0 * * * ggf. anpassen, bedeutet "jeden Tag um 0:02 Uhr"
funktioniert tadellos, seither keine Verbindungsabbrüche mehr
-
@Latzi Dann kommt das so ins WiKi.
Ich hätte ja noch gerne den Batteriestatus, aber der wird leider nicht übertragen (was sollte auch Wunderground mit diesem "Messwert" anfangen...?).
Mir schwebt aber noch ein DP ala "Kommunikationsfehler" vor. Wenn bspw. 5x hintereinander keine korrekten Messwerte übertragen wurden, wird der DP "true". Dann kann man darauf triggern und in der VIS anzeigen lassen oder was auch immer...
So bekäme man bspw. auch zeitnah leere Batterien mit -
@SBorg gute Idee
@SBorg sagte in [Linux Shell-Skript] WLAN-Wetterstation:
Wenn bspw. 5x hintereinander keine korrekten Messwerte übertragen wurden
PS: Das setzt voraus, dass nc durchlaufen wird, ich bin mir nicht sicher was eigentlich gegen Mitternacht passiert, wenn keine Daten mehr kommen.
-
@Latzi Ich habe da schon ein Konstrukt. Aktuell starte ich 5 Sekunden vor dem Ende des Poll-Intervalls den nc. Kommt ein Datenpaket (egal ob gültig oder nicht) beendet sich der nc von alleine und die empfangenen Daten werden ausgewertet.
Meine neue Idee ist nun, dass ich den nc nur max. 10 Sekunden laufen lasse und dann automatisch beende. Dabei gibt es zwei Szenarien:- es kommt innerhalb der 10 Sekunden ein Datenpaket
- es kommt kein Datenpaket und der nc wird terminiert
Ich prüfe nun das Datenpaket, ob es zB. "/weatherstation/updateweatherstation.php?ID=[Bezeichnung]" enthält, dann dürfte es zumindest ein Datenpaket mit Wetterdaten sein (ev. wird alle zz Stunden xyz geschickt, wann und wohin uns nicht interessiert) und ob es eine Mindestlänge von 400 Zeichen (je nach ID, Passwortlänge + Messwerten sind +/- 430 Zeichen normal) hat.
-
@Rushmed sagte in [Linux Shell-Skript] WLAN-Wetterstation:
Sagt mal was ist denn jetzt die schlauste Art meine Wetterdaten zu loggen wenn ich die immer am Jahresende in Excel aufbereiten will?
Mit dem History Adapter sehe ich da noch keinen Weg.Ich nutze dafür eine influxDB. Das kann man auch schön visualisieren, hinein/hinaus zoomen, scrollen usw (mangels Wetterstation halt mit den Daten):
Die Daten kann man sich dann komfortabel "von bis" zB. als CSV exportieren, sortieren,...
-
Hi,
habe meine Sainlogic heute bekommen und wollte gleich mal in ioBroker einbinden.
Leider bekomme ich bei der Scriptausführung eine Fehlermeldung wo ich nicht weiter weiß.Listening on [0.0.0.0] (family 2, port 8096) nc: getnameinfo: Temporary failure in name resolution (standard_in) 1: syntax error (standard_in) 1: syntax error (standard_in) 1: syntax error (standard_in) 1: syntax error (standard_in) 1: syntax error (standard_in) 1: syntax error (standard_in) 1: syntax error (standard_in) 1: syntax error (standard_in) 1: syntax error (standard_in) 1: syntax error
Einstellungen alles laut Wiki und dennoch wir die Wetterstation anscheinend nicht erreicht.
Am RaspPi 4 läuft der ioBroker und auch das Script.Hoffe jemand kann mir auf die Sprünge helfen.
ERLEDIGT:
Der DNS Eintrag des Raspberry Pi war ein externer server. Nachdem ich nun noch meine Router IP in den DNS-Eintrag dazugefügt habe, findet nc nun die Wetterstation und es kommen Daten an!Grüße
Tritor -
@SBorg
Das sieht sehr nice aus, gibts da ne gute Anleitung?
Hab influxDB inkl. ioBroker Adapter (grün) jetzt laufen aber im FLOT kommen keine Werte an. -
@tritor sagte in [Linux Shell-Skript] WLAN-Wetterstation:
ERLEDIGT:
Der DNS Eintrag des Raspberry Pi war ein externer server. Nachdem ich nun noch meine Router IP in den DNS-Eintrag dazugefügt habe, findet nc nun die Wetterstation und es kommen Daten an!Sehr gut! Welche Wetterstation?
-
@Rushmed
Sainlogic 7 in 1 WiFi Weather Station, Model WS3500 -
@Rushmed sagte in [Linux Shell-Skript] WLAN-Wetterstation:
@SBorg
Das sieht sehr nice aus, gibts da ne gute Anleitung?
Hab influxDB inkl. ioBroker Adapter (grün) jetzt laufen aber im FLOT kommen keine Werte an.Das ist mittels Grafana erstellt und wird dann wie FLOT als iFrame dargestellt. Anleitung hatte ich keine, hab es nach dem "try and error"-Prinzip gelernt
@crunchip hat da auch mal was in Grafana gebaut: https://forum.iobroker.net/post/356736bzgl. Daten: Aaarrrgghh, hab den k*ck schon befürchtet. Der History-Adapter schreibt schon nix wenn ack=false ("bestätigt"), der InfluxDB auch...
Die Daten einzeln in den ioB zu schreiben dauert einfach zu lange (da geht ack=true). Per iobroker setstate... geht es ebenfalls, dauert aber auch wieder zu lange (15x aufrufen). Bliebe noch es direkt in die InfluxDB zu schreibenWer einen (auch kostenlosen) GitHub-Acc hat, kann auch gerne voten, bei genügend Interesse passiert auch was^^:
https://github.com/ioBroker/ioBroker.simple-api/issues/29 -
@SBorg sagte in [Linux Shell-Skript] WLAN-Wetterstation:
bzgl. Daten: Aaarrrgghh, hab den k*ck schon befürchtet. Der History-Adapter schreibt schon nix wenn ack=false ("bestätigt"), der InfluxDB auch...
Die Daten einzeln in den ioB zu schreiben dauert einfach zu lange (da geht ack=true). Per iobroker setstate... geht es ebenfalls, dauert aber auch wieder zu lange (15x aufrufen). Bliebe noch es direkt in die InfluxDB zu schreibenÜber History bekomm ich in FLOT Daten, aber halt mit influx nicht!?
-
"Lustig", dann muss sich in letzter Zeit etwas geändert haben. Aber die Influx bleibt bei mir auch leer. Er legt zwar die Serie an, schreibt aber keinerlei Daten hinein. Setze ich den DP mittels iobroker state set "javascript.0...." 123 true geht es (true entspricht ack=true).
Die neue V0.1.2 steht bald zum Beta-Test bereit. Die muss vorher getestet werden, da ich hier ohne Station nicht mehr sicher bin ob auch alles funktioniert und es nicht mehr simulieren kann.