NEWS
[Linux Shell-Skript] WLAN-Wetterstation
-
@omnedon Ist genau im 15 Minuten-Raster, dürfte also Influx sein...
- Influx V2.x? Aktuell geht nur V1.x
- bei V1.x: User, Passwort, Datenbankname etc. stimmen für Influx alle? Entsprechende Datenpunkte werden geloggt?
-
@omnedon Ist genau im 15 Minuten-Raster, dürfte also Influx sein...
- Influx V2.x? Aktuell geht nur V1.x
- bei V1.x: User, Passwort, Datenbankname etc. stimmen für Influx alle? Entsprechende Datenpunkte werden geloggt?
-
Testrunde...
für die Rest-API, also nur für Leutz die sie eh schon haben oder jetzt damit mal anfangen wollen...
Aktuellews_updater.betaherunterladen (https://github.com/SBorg2014/WLAN-Wetterstation/blob/master/ws_updater.beta) und "ausführbar" machen mittelschmod +x ./ws_updater.beta
Im Installationsverzeichnis (ist nur für den Test) eine neue Datei wetterstation.conf.temp (zB.nano wetterstation.conf.tempmit folgendem Inhalt anlegen:RESTAPI_URL=https://192.168.1.3:8093 RESTAPI_USER=apiknecht RESTAPI_PW=geheim PRE_DP=0_userdata.0.Test_RestAPI- URL dürfte klar sein (ioB + Port der Rest-API
- User und Passwort kann man auch den "admin" nehmen, ich empfehle allerdings eher sich einen neuen User mit entsprechenden Rechten im ioB dafür anzulegen. Zum Test kann man ausnahmsweise auch mal den "admin" nutzen ;)
- PRE_DP könnt ihr so lassen, ist ein reiner Testdatenpunkt der nachher sowieso wieder gelöscht werden kann/muss
Test #1:
./ws_updater.beta --test

dann sollte hoffentlich im IoB unter "0_userdata.0." auftauchen:

Test #2:
do_it_again... ;)
./ws_updater.beta --test
Dann hat alles funktioniert und kann in die zukünftigen Updater-Versionen 8)
Kpl. Objectbaum und "wetterstation.conf.temp" können gelöscht werden.
@sborg sagte in [Linux Shell-Skript] WLAN-Wetterstation:
oder jetzt damit mal anfangen wollen...
irgendwas passt bei mir noch nicht
kannst du mal drübetschaun?dietpi@DietPi:/$ ./ws_updater.beta --test -bash: ./ws_updater.beta: Datei oder Verzeichnis nicht gefunden dietpi@DietPi:/$ -
@sborg sagte in [Linux Shell-Skript] WLAN-Wetterstation:
oder jetzt damit mal anfangen wollen...
irgendwas passt bei mir noch nicht
kannst du mal drübetschaun?dietpi@DietPi:/$ ./ws_updater.beta --test -bash: ./ws_updater.beta: Datei oder Verzeichnis nicht gefunden dietpi@DietPi:/$@negalein :( leider wieder was vergessen, oben schon geändert.
...und "ausführbar" machen mittels
chmod +x ./ws_updater.betaBeim http(s) der Rest-API URL bin ich mir gerade nicht sicher. Müsste eigentlich mittels "https" laufen.
-
Wie so oft im Leben sitzt das Problem vor dem Computer!
Hab den Fehler gefunden - soweit alles gut.Nachdem ich den Service in meiner Proxmox7 VM gestoppt habe und im simple adapter immer noch alle 15 Minuten die "Leereinträge" der Wetterdaten und Drucktendenz kamen mußten die auf jeden Fall von einem anderen System kommen.
Ja ich hätte im Testsystem (hab ich vor kurzem wieder angeworfen und alle nicht relevanten Adapter gestoppt) auch das Wetterscript ändern sollen. Aus diesem kamen die Daten. Nachdem ich dort in Proxmox6 Testsystem Service und Files/Folders
der Wetterstation gelöscht, und dann wieder im Livesystem das Script aktiviert habe, kommen die Wetterdaten alle 15 Minuten nur 1x und alles geht soweit ich das im Log gesehen habe seinen gewohnten Gang.Also sollte so ein Fehler nochmals vorkommen, dann ist wahrscheinlich ein altes oder ein Testsystem noch aktiv.
@tritor sagte in [Linux Shell-Skript] WLAN-Wetterstation:
Wie so oft im Leben sitzt das Problem vor dem Computer!
Hauptdache läuft 8) :+1:
Da lag ich (steht irgendwo weiter oben) sogar richtig, dass irgend was anderes noch laufen muss, denn zu den Zeitpunkten kann das Skript selbst nichts machen. Das 2. hat dann munter auf das folgende Paket reagiert ;)Trotzdem kommt man immer selbst ins grübeln...
-
@sborg said in [Linux Shell-Skript] WLAN-Wetterstation:
@viper4iob Ich habe jetzt mal die beiden 10min-Werte eingebaut, in der Simulation funktioniert es auch.
Wenn ich es schaffe lade ich es noch heute zum testen auf GitHub hoch :)
...spätestens (hoffentlich) dann morgen...Vielen Dank für die schnelle Umsetzung.
Dann hätte ich doch noch mal eine Idee. Ich habe mir mal die 10 min Durchschnittswerte angeschaut.
Und gerade bei der Windrichtung bügelt das das extreme Schwanken der Fahne durch verwirbelte Luft oder vielleicht schlechtes Design ganz gut aus. In einem Graphen sieht es auf jeden Fall deutlich besser aus.
Die Frage wäre jetzt, ob man eine Option in die config einbauen könnte, dass zu den externen Diensten wie wetter.com oder OpensenseMap ... statt dem normalen Wert der 10 min Wert übertragen wird. Für die Windrichtung würde das Sinn machen, denke ich. Bei der Wind-Geschwindigkeit bin ich mir nicht so sicher. Eventuell macht es Sinn für beide Werte eine getrennte Option zu haben. Dann kann das jeder selbst entscheiden.
Ich sammle jetzt mal bis morgen die Daten, dann kann ich vielleicht mal Screenshots von Graphen aus iobroker im Vergleich zeigen.@viper4iob Ich überlege jetzt schon einige Zeit. Parameter in der conf wäre zwar am flexibelsten, aber es sind eigentlich auch schon genügend vorhanden (für die Rest-API kommen ja auch wieder neue hinzu).
Ich denke weiter, was meint denn der Rest?
Ich könnte die letzten 10 Minuten (bzw. zB 20 Werte) im RAM halten (paar kB und der Adapter kommt eh mit <10MB RAM aus) und daraus immer einen Mittelwert bilden für die Stationen die es nicht selbst ermitteln.
Ich sehe mein Windfähnchen immer "propellern", da ist alle 30 Sekunden ein Momentanwert auch eher nichtssagend. -
@negalein :( leider wieder was vergessen, oben schon geändert.
...und "ausführbar" machen mittels
chmod +x ./ws_updater.betaBeim http(s) der Rest-API URL bin ich mir gerade nicht sicher. Müsste eigentlich mittels "https" laufen.
@sborg sagte in [Linux Shell-Skript] WLAN-Wetterstation:
Beim http(s) der Rest-API URL bin ich mir gerade nicht sicher. Müsste eigentlich mittels "https" laufen.
mit
httpist die Meldung gekommen, dass es angelegt wurde.
In0.userdatawar es aber nicht da.mit
httpsfunktioniert es perfekt.Lege neues Object im ioBroker an: 0_userdata.0.Test_RestAPI.Info.Meldungen dietpi@DietPi:/home/iobroker$ ./ws_updater.beta --test ┌────────────────────────┐ │ │ │ WS-Updater V2.15.0 │ │ │ └────────────────────────┘ Lege neues Object im ioBroker an: 0_userdata.0.Test_RestAPI.Info.Meldungen Fehlermeldung beim Anlegen des Datenpunktes: {"error":"Object already exists","id":"0_userdata.0.Test_RestAPI.Info.Meldungen"} dietpi@DietPi:/home/iobroker$
-
@sborg sagte in [Linux Shell-Skript] WLAN-Wetterstation:
Beim http(s) der Rest-API URL bin ich mir gerade nicht sicher. Müsste eigentlich mittels "https" laufen.
mit
httpist die Meldung gekommen, dass es angelegt wurde.
In0.userdatawar es aber nicht da.mit
httpsfunktioniert es perfekt.Lege neues Object im ioBroker an: 0_userdata.0.Test_RestAPI.Info.Meldungen dietpi@DietPi:/home/iobroker$ ./ws_updater.beta --test ┌────────────────────────┐ │ │ │ WS-Updater V2.15.0 │ │ │ └────────────────────────┘ Lege neues Object im ioBroker an: 0_userdata.0.Test_RestAPI.Info.Meldungen Fehlermeldung beim Anlegen des Datenpunktes: {"error":"Object already exists","id":"0_userdata.0.Test_RestAPI.Info.Meldungen"} dietpi@DietPi:/home/iobroker$
@negalein Supi, danke für das testen. Dann können sich zukünftig Rest-API Nutzer freuen (für die kommende V2.15.0 ist es dafür leider schon zu spät) :)
Bei falschem Protokoll kommt leider keinerlei Fehlermeldung zurück, dafür aber überhaupt nix. Auf "nix" kann ich aber reagieren:

-
Hallo,
Zur Info:
ich konnte heute meine Froggit WH6000Pro erfolgreich einbinden.Gruß
Mugel80@mugel80 Danke für die Rückmeldung und kommt gleich mit in die Liste :+1:
Willkommen bei den Wetterfröschen 8)
-
@mugel80 Danke für die Rückmeldung und kommt gleich mit in die Liste :+1:
Willkommen bei den Wetterfröschen 8)
Vis & Kompass:
Bei der Neugestaltung meiner Wetterdaten Vis, benutue ich das Compass Widget.
Leider wir das nach einigen Minuten fehkerhaft und zeigt eine Verschiebung:
Tritt beim Firefox 102.0.1 (64-Bit) unter MacOS auf, der der aktuelle Safari 15.15 am MBPro hat kein Problem damit auch beim MS Edge 103.0.1264.51 unter OSX habe ich kein Problem festgestellt.
Ist also definitiev ein browserabhängiges Problem. Leider hab ich im Moment keinen Wondowsrechner zur Verfügung und kann das mit dem FF leider nicht testen.
-
Vis & Kompass:
Bei der Neugestaltung meiner Wetterdaten Vis, benutue ich das Compass Widget.
Leider wir das nach einigen Minuten fehkerhaft und zeigt eine Verschiebung:
Tritt beim Firefox 102.0.1 (64-Bit) unter MacOS auf, der der aktuelle Safari 15.15 am MBPro hat kein Problem damit auch beim MS Edge 103.0.1264.51 unter OSX habe ich kein Problem festgestellt.
Ist also definitiev ein browserabhängiges Problem. Leider hab ich im Moment keinen Wondowsrechner zur Verfügung und kann das mit dem FF leider nicht testen.
@tritor
Ich setzte dieses Widget ein, welches bisher ohne Probleme funktioniert:[{"tpl":"tplCGCompas","data":{"g_fixed":true,"g_visibility":false,"g_css_font_text":false,"g_css_background":false,"g_css_shadow_padding":false,"g_css_border":false,"g_gestures":false,"g_signals":false,"g_last_change":false,"visibility-cond":"==","visibility-val":1,"visibility-groups-action":"hide","minValue":"0","maxValue":"360","factor":"1","valueOffset":"0","hCount":"1","majorTicks":"N,NO,O,SO,S,SW,W,NW,N","minorTicks":"22","strokeTicks":"false","animation":"true","animationDuration":"1000","colorPlate":"#222","colorMajorTicks":"#f5f5f5","colorMinorTicks":"#ddd","colorNumbers":"#ccc","colorNeedle":"rgba(240,128,128,1)","colorNeedleEnd":"rgba(255,160,122,.9)","colorBorderOuter":"#ccc","colorBorderOuterEnd":"#ccc","colorNeedleShadowDown":"#222","needleType":"line","needleStart":"75","needleEnd":"99","needleWidth":"3","borders":"true","borderOuterWidth":"4","borderMiddleWidth":"0","borderInnerWidth":"0","borderShadowWidth":"0","valueBox":true,"valueTextShadow":"false","ticksAngle":"360","startAngle":"180","colorNeedleCircleOuter":"#ccc","needleCircleSize":"15","needleCircleOuter":"false","signals-cond-0":"==","signals-val-0":true,"signals-icon-0":"/vis.0/Weatherman/lowbattery.png","signals-icon-size-0":0,"signals-blink-0":false,"signals-horz-0":0,"signals-vert-0":0,"signals-hide-edit-0":false,"signals-cond-1":"==","signals-val-1":true,"signals-icon-1":"/vis.0/Weatherman/lowbattery.png","signals-icon-size-1":0,"signals-blink-1":false,"signals-horz-1":0,"signals-vert-1":0,"signals-hide-edit-1":false,"signals-cond-2":"==","signals-val-2":true,"signals-icon-2":"/vis.0/Weatherman/lowbattery.png","signals-icon-size-2":0,"signals-blink-2":false,"signals-horz-2":0,"signals-vert-2":0,"signals-hide-edit-2":false,"lc-type":"last-change","lc-is-interval":true,"lc-is-moment":false,"lc-format":"","lc-position-vert":"top","lc-position-horz":"right","lc-offset-vert":0,"lc-offset-horz":0,"lc-font-size":"12px","lc-font-family":"","lc-font-style":"","lc-bkg-color":"","lc-color":"","lc-border-width":"0","lc-border-style":"","lc-border-color":"","lc-border-radius":10,"lc-zindex":0,"oid":"0_userdata.0.Wetterstation.Windrichtung","units":"°","title":"Wind","valueDec":"0","name":"Windrichtung"},"style":{"left":"245px","top":"34px"},"widgetSet":"canvas-gauges"}] -
hättest du die Windrose als gesamten Widgetcode zur Verfügung?
Auf welchem Wideget basiert es? Ich hätte versucht mit dem Kompass-Widget zu arbeiten, bekomme aber keine Grafik rein. -
hättest du die Windrose als gesamten Widgetcode zur Verfügung?
Auf welchem Wideget basiert es? Ich hätte versucht mit dem Kompass-Widget zu arbeiten, bekomme aber keine Grafik rein. -
eh so einfach .. danke, habs hinbekommen
-
eh so einfach .. danke, habs hinbekommen
-
Mal ein kleiner "Schwenk" aus dem Alltag des Devs. Wie berechnet man die durchschnittliche Windrichtung von sagen wir 20 Messwerten?
Vor dem "spoilern" mal kurz darüber nachdenken, dann spoilern und staunen :)
Wer mir das erklärt, dem "nogger ich einen" 8) -
Mal ein kleiner "Schwenk" aus dem Alltag des Devs. Wie berechnet man die durchschnittliche Windrichtung von sagen wir 20 Messwerten?
Vor dem "spoilern" mal kurz darüber nachdenken, dann spoilern und staunen :)
Wer mir das erklärt, dem "nogger ich einen" 8)@sborg sagte in [Linux Shell-Skript] WLAN-Wetterstation:
Wer mir das erklärt, dem "nogger ich einen" 8)
Da hast du absolut recht - net easy, da muß man schon ein wenig rechnen.
Das gab es schon mal im Loxone Forum und da war ein Link auf https://en.wikipedia.org/wiki/Yamartino_method -
@speedy sagte in [Linux Shell-Skript] WLAN-Wetterstation:
da die Fehlermeldung keine Anzeichen liefert, wo der "parse error" entsteht, kann ich nicht wirklich weitersuchen.
Der entsteht "einfach" dadurch, dass keine Daten zum verarbeiten da sind und man mathematisch nicht durch "0" teilen kann/darf (oder wie das war). An der Stelle also alles iO.
Dein Messwerteblock ist aber kpl. leer, es kommen also keine Daten von deinem Display/Gateway. Dafür spricht auch Kommunikationsfehler
Nicht falsch verstehen, ist wie beim Auto das nicht fährt und darauf die Frage Treibstoff haben sie aber im Tank?, aber genau an die Installationsanleitung im Wiki gehalten? 99% der Fehler sind falscher "Pfad" in der App/oder falsche IP-Adresse (es muss wirklich die sein auf dem das Skript läuft. Das kann der ioB-Rechner sein, muss aber nicht ;) ). Danach folgt falscher Port (der muss in App und conf identisch sein), oder Port ist nicht frei (solange das Skript/Service nicht läuft darf einsudo netstat -tulpen|grep 9999kein Ergebnis liefern)
-
- Versuch: Port 1081 frei
-
- Versuch: Port 1080 belegt durch "nc" (logo, dort läuft das Skript :) )
@sborg
Hallo sborg,sorry, aber habe erst jetzt wieder Zeit gefunden, danke für deine Antwort.
Ich bin die ganze Konfiguration nochmals durchgegangen und konnte keinen Fehler finden.
Die IP-Adressen, Ports und Pfade sind korrekt. Das Scritp läuft auch:psw@iobroker:~$ sudo netstat -tulpen|grep 9999 [sudo] Passwort für psw: tcp 0 0 0.0.0.0:9999 0.0.0.0:* LISTEN 1001 12990328 11270/io.sainlogic. psw@iobroker:~$Aber eine Fehlermeldung bleibt:
./wetterstation.sh --debug WLAN-Wetterstation V2.14.0 - (c)2019-2022 by SBorg Config-Version: V2.14.0 Sub-Version : V2.14.0 'bc' installiert: [✓] 'jq' installiert: [✓] 'nc' in der Openbsd-Variante installiert: [✓] 'netcat' in Openbsd-Variante aktiv, alles korrekt [✓] Connection to 192.168.1.8 8087 port [tcp/*] succeeded! jq: error (at <stdin>:7): Cannot iterate over null (null) jq: error (at <stdin>:7): Cannot iterate over null (null) Messwerteblock: Nicht alle Werte werden unterstützt (abhängig vom Modell der Wetterstation und dem verwendeten Protokoll)! Temperatur Innen : °C Temperatur Aussen : °C Taupunkt : °C Gefühlte Temperatur : °C Luftfeuchte Innen : % Luftfeuchte Aussen : % Windgeschwindkeit : km/h Windböengeschwindigkeit : km/h max. Windböe : km/h Windrichtung : ° Windrichtung : Luftdruck absolut : hPa Luftdruck relativ : hPa Regenrate : mm/h Regenstatus : Regen seit Regenbeginn : mm Regen Stunde : mm Regen Tag : mm Regen Woche : mm Regen Monat : mm Regen Jahr : mm Regen Gesamt : mm Sonnenstrahlung : W/m² UV-Index : Zeitstempel : Firmware : Batteriestand: : Gateway-Modell : Zusatzsensoren: Datenstring für ioBroker: DATA von Wetterstation: Debug VAR: Installationsverzeichnis: /home/iobroker IPP: 192.168.1.8:8087 WS_PORT: 9999 WS_POLL: 20 PRE_DP: javascript.0.Wetterstation WEB: HTTP WS_PROT: Ecowitt DP35/40/50/60/70/100/200/250/300: 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 WH31: 0 Script-Version: V2.14.0 Config-Version: V2.14.0 Sub-Version: V2.14.0 Kommunikationsfehler! root@iobroker:/home/iobroker#Was ich nicht verstehen kann ist, dass er eine Verbindung zum Simple-RESTful aufbauen kann, aber dann keine Daten erhält oder findet. Wo sollten diese sein?
soweit ich es verstanden habe, holt sich das Script die Daten über den RESTful Adapter, woher bekommt diese die Daten?Bin ratlos....
Liegt es evtl. daran, dass meine Sainlogic keinen Scheduler Mode kann?
D.h. es funktioniert nur der Listener... -







