NEWS
[Linux Shell-Skript] WLAN-Wetterstation
-
@boronsbruder Hast du ebenfalls ein Multihost-System? Das kann ich leider nicht testen und der Test auf die Rest-API müsste auch schon jetzt funktionieren, da der ohne Zugangsdaten nur mittels "iob" ausgeführt wird.
Was liefert denn ein
iob status rest-api.0? Genau die Ausgabe wird auf is running geprüft. -
@martybr sagte in [Linux Shell-Skript] WLAN-Wetterstation:
@sborg
Ich habe ein Multihast-System. Auf einem Slave läuft die Simple.API. Ich habe nun auf dem Master die Rest.API installiert. Der Update V2.15 erkennt diese nicht. Kann es sein, dass die Rest.API auf dem gleichen Host wie die Simple.API installiert werden muss? Dann hätte ich die die Bitte, dass der Server für die Rest.API konfiguriert werden könnte (Eingabe IP).Danke für das tolle Projekt, die Wetterstation läuft Tiptop!
Nein, wo ist egal. Allerdings beißt sich da der Hund selbst in den Schwanz (einmalig). Zur 1. Laufzeit prüft er auf die Rest-API, hat aber in der *.conf noch keine Zugangsdaten. Wenn du die also jetzt einträgst "lüppt dat och" ;)
Hast du eine HP1000SE Pro ?
+Windrichtung und -geschwindigkeit der letzten 10 Minuten (aktuell HP1000SE Pro)
Nur die unterstützt das derzeit. Mit der kommenden V2.16.0 (bald als Beta) berechne ich die Windrichtung für alle Stationen. Geschwindigkeit muss ich dann noch umsetzen.
-
@mugel80 sagte in [Linux Shell-Skript] WLAN-Wetterstation:
Mach ich was falsch?
Offenbar werkelst du da als root herum.
Warum auch immer. Das ist schonmal grundsätzlich falsch.Also als user anmelden und das skript mit den richtigen Rechten (als Standard-User!) ausführen.
@thomas-braun sagte in [Linux Shell-Skript] WLAN-Wetterstation:
@mugel80 sagte in [Linux Shell-Skript] WLAN-Wetterstation:
Mach ich was falsch?
Offenbar werkelst du da als root herum.
Warum auch immer. Das ist schonmal grundsätzlich falsch.Also als user anmelden und das skript mit den richtigen Rechten (als Standard-User!) ausführen.
Hab den Fehler gefunden.
Danke für die Hilfe. -
@sborg Ich habe die DP1500 Wi-Fi Wetterserver USB-Dongle & WH3000SE All-in-One Außensensor mit dem DP100 Bodenfeuchtesensor.
@martybr So ganz mag es mir noch nicht einleuchten. Aber an der Hardware liegt es nicht.
Ich habe zwar mal wieder ein Gleichheitszeichen vergessen, müsste aber bei "Debian" als Distri egal sein (zumindest läuft es bei mir und @Negalein hatte mit seiner Diät-Himbeere [:blush: ] auch keine Probleme).Immerhin liefert auch der Multihost die selbe Ausgabe. Versuche bitte mal die aktuelle (eigentlich falsche) Version (2 Befehle nacheinander):
test=$(iob status rest-api.0|cut -d'"' -f3) if [ "${test}" = " is running" ]; then echo API läuft; fidann die korrekte:
test=$(iob status rest-api.0|cut -d'"' -f3) if [ "${test}" == " is running" ]; then echo API läuft; fizu guter Letzt die neue und eleganteste mittels RegEx:
if [[ $(iob status rest-api.0) =~ "is running" ]]; then echo API läuft; fi -
@martybr So ganz mag es mir noch nicht einleuchten. Aber an der Hardware liegt es nicht.
Ich habe zwar mal wieder ein Gleichheitszeichen vergessen, müsste aber bei "Debian" als Distri egal sein (zumindest läuft es bei mir und @Negalein hatte mit seiner Diät-Himbeere [:blush: ] auch keine Probleme).Immerhin liefert auch der Multihost die selbe Ausgabe. Versuche bitte mal die aktuelle (eigentlich falsche) Version (2 Befehle nacheinander):
test=$(iob status rest-api.0|cut -d'"' -f3) if [ "${test}" = " is running" ]; then echo API läuft; fidann die korrekte:
test=$(iob status rest-api.0|cut -d'"' -f3) if [ "${test}" == " is running" ]; then echo API läuft; fizu guter Letzt die neue und eleganteste mittels RegEx:
if [[ $(iob status rest-api.0) =~ "is running" ]]; then echo API läuft; fi -
@martybr So ganz mag es mir noch nicht einleuchten. Aber an der Hardware liegt es nicht.
Ich habe zwar mal wieder ein Gleichheitszeichen vergessen, müsste aber bei "Debian" als Distri egal sein (zumindest läuft es bei mir und @Negalein hatte mit seiner Diät-Himbeere [:blush: ] auch keine Probleme).Immerhin liefert auch der Multihost die selbe Ausgabe. Versuche bitte mal die aktuelle (eigentlich falsche) Version (2 Befehle nacheinander):
test=$(iob status rest-api.0|cut -d'"' -f3) if [ "${test}" = " is running" ]; then echo API läuft; fidann die korrekte:
test=$(iob status rest-api.0|cut -d'"' -f3) if [ "${test}" == " is running" ]; then echo API läuft; fizu guter Letzt die neue und eleganteste mittels RegEx:
if [[ $(iob status rest-api.0) =~ "is running" ]]; then echo API läuft; fi@sborg sagte in [Linux Shell-Skript] WLAN-Wetterstation:
if [ "${test}" = " is running" ]; then echo API läuft; fi
Zum ersten Block:
martin@iobroker:~$ test=$(iob status rest-api.0|cut -d'"' -f3) martin@iobroker:~$ if [ "${test}" = " is running" ]; then echo API läuft; fi API läuftHier der zweite Block:
martin@iobroker:~$ test=$(iob status rest-api.0|cut -d'"' -f3) martin@iobroker:~$ if [ "${test}" == " is running" ]; then echo API läuft; fi API läuftUnd nun die elegante Lösung:
martin@iobroker:~$ if [[ $(iob status rest-api.0) =~ "is running" ]]; then echo API läuft; fi API läuft martin@iobroker:~$Die Befehle habe ich alle auf dem Master gestartet, wo auch die Rest.api läuft.
-
Da keine offensichtlichen Fehler aufgetreten sind:
Neues Release des Wetterstation WLAN-Skriptes auf GitHub V2.15.0
- + neuer DP "Meldungen"; für Status- und Fehlermeldungen
- + Datenübertragung an Wunderground.com auch bei eigenem DNS-Server (Protokoll #9)(@git-ZeR0)
- + Windrichtung und -geschwindigkeit der letzten 10 Minuten (aktuell HP1000SE Pro)
- + ws_updater: anlegen neuer Datenpunkte per Rest-API möglich
Wie immer zu finden im GitHub
Update-Routine von Vorgängerversion:
- aktuellen WS-Updater nutzen (Download falls älter als V2.12.1:
wget -O ws_updater.sh https://raw.githubusercontent.com/SBorg2014/WLAN-Wetterstation/master/ws_updater.sh) - wetterstation.js muss ebenfalls im JavaScript-Adapter ersetzt und einmalig ausgeführt werden (neue Datenpunkte)
./ws_updater.shim Installationsverzeichnis ausführen- Menüpunkt "4" wählen und die Fragen beantworten
Update kann durchgeführt werden wenn man die neuen Funktionen nutzen möchte oder einfach aktuell sein möchte ;)
Mit diesem Update unterstützt der ws_updater zukünftig die Rest-API. Somit können Nutzer der Rest-API in Zukunft auf die Änderungen mittels der wetterstation.js verzichten. Dies erledigt dann die Rest-API.
Der Einsatz der Rest-API ist nicht zwingend erforderlich sondern rein optional möglich! Bei installierter Rest-API (dies prüft der ws_updater) werden die ggf. neuen Datenpunkte automatisch angelegt, ansonsten muss man halt weiter wie gehabt die wetterstation.js-Routine nutzen.irgendwie will mein service nach dem update auf 2.15 nicht mehr laufen. Es wird ein Versionsunterschied gemeldet, obwohl ich das service "restartet" habe und auch den iobroker neu gestartet habe.
Hast du eine Idee?Anbei noch die Installation (mit einer seltsamen influx-Meldung - influx hab ich gar nicht konfiguriert - alles leer)
Auswahlmenü für WLAN-Wetterstation: _____________________________________ [1] im aktuellen Verzeichnis installieren [2] als Service einrichten [3] Konfigurationsdatei patchen [4] Update ausführen [E] Exit Ihre Auswahl: [1-4]: 4 ┌────────────────────────┐ │ │ │ WS-Updater V2.15.0 │ │ │ └────────────────────────┘ /dev/fd/62: Zeile 23: /dev/fd/wetterstation.conf: Datei oder Verzeichnis nicht gefunden /dev/fd/62: Zeile 63: influxd: Kommando nicht gefunden. Offizieller Support nur für Influx V1.x! 'bc' installiert: [✓] 'jq' installiert: [✓] 'unzip' installiert: [✓] 'patch' installiert: [✓] 'Rest-API' im ioBroker installiert: [✗] (Dies ist kein Problem, es können nur ggf. keine neuen Datenpunkte automatisch angelegt werden. Dies muss bei Bedarf per 'wetterstation.js' von Hand im ioBroker erfolgen.) Aktuelle Version (latest) auf GitHub: V2.15.0 vom 19.06.2022 Version im aktuellen Verzeichnis : V2.15.0 Version ist bereits aktuell... latzi@ioBroker:~$ systemctl status wetterstation ● wetterstation.service - Service für ioBroker Wetterstation Loaded: loaded (/etc/systemd/system/wetterstation.service; enabled; vendor preset: enabled) Active: failed (Result: exit-code) since Tue 2022-07-19 06:29:31 CEST; 11min ago Process: 12479 ExecStart=/home/latzi/wetterstation.sh (code=exited, status=1/FAILURE) Main PID: 12479 (code=exited, status=1/FAILURE) CPU: 7ms Jul 19 06:29:31 ioBroker wetterstation.sh[12479]: wetterstation: ERROR #000 - Config-Version mismatch! Jul 19 06:29:31 ioBroker wetterstation.sh[12479]: benutzt: V2.14.0 benötigt wird: V2.15.0EDIT: erledigt, hab die
wetterstation.confauf 2.15 geändert und nun läuft´s -
@sborg sagte in [Linux Shell-Skript] WLAN-Wetterstation:
if [ "${test}" = " is running" ]; then echo API läuft; fi
Zum ersten Block:
martin@iobroker:~$ test=$(iob status rest-api.0|cut -d'"' -f3) martin@iobroker:~$ if [ "${test}" = " is running" ]; then echo API läuft; fi API läuftHier der zweite Block:
martin@iobroker:~$ test=$(iob status rest-api.0|cut -d'"' -f3) martin@iobroker:~$ if [ "${test}" == " is running" ]; then echo API läuft; fi API läuftUnd nun die elegante Lösung:
martin@iobroker:~$ if [[ $(iob status rest-api.0) =~ "is running" ]]; then echo API läuft; fi API läuft martin@iobroker:~$Die Befehle habe ich alle auf dem Master gestartet, wo auch die Rest.api läuft.
@martybr Danke für das testen und es gibt auch so schon durchaus wichtigeres... ;)
...und ich sitze auch nicht rum und warte :)Der Fehler ist aber nicht in der Abfrage (vom fehlenden "=" mal abgesehen), sondern eher gedanklicher Natur. Die Abfrage kann so nur funktionieren wenn "ioB-Rechner" = "Rechner auf dem das Skript läuft" ist. Fixed mit der nächsten Version :heavy_check_mark:
Da in der V2.15.0 die Rest-API noch keinen Einsatz erfährt ist es nur ein kosmetisches/Anzeige Problemchen.
-
irgendwie will mein service nach dem update auf 2.15 nicht mehr laufen. Es wird ein Versionsunterschied gemeldet, obwohl ich das service "restartet" habe und auch den iobroker neu gestartet habe.
Hast du eine Idee?Anbei noch die Installation (mit einer seltsamen influx-Meldung - influx hab ich gar nicht konfiguriert - alles leer)
Auswahlmenü für WLAN-Wetterstation: _____________________________________ [1] im aktuellen Verzeichnis installieren [2] als Service einrichten [3] Konfigurationsdatei patchen [4] Update ausführen [E] Exit Ihre Auswahl: [1-4]: 4 ┌────────────────────────┐ │ │ │ WS-Updater V2.15.0 │ │ │ └────────────────────────┘ /dev/fd/62: Zeile 23: /dev/fd/wetterstation.conf: Datei oder Verzeichnis nicht gefunden /dev/fd/62: Zeile 63: influxd: Kommando nicht gefunden. Offizieller Support nur für Influx V1.x! 'bc' installiert: [✓] 'jq' installiert: [✓] 'unzip' installiert: [✓] 'patch' installiert: [✓] 'Rest-API' im ioBroker installiert: [✗] (Dies ist kein Problem, es können nur ggf. keine neuen Datenpunkte automatisch angelegt werden. Dies muss bei Bedarf per 'wetterstation.js' von Hand im ioBroker erfolgen.) Aktuelle Version (latest) auf GitHub: V2.15.0 vom 19.06.2022 Version im aktuellen Verzeichnis : V2.15.0 Version ist bereits aktuell... latzi@ioBroker:~$ systemctl status wetterstation ● wetterstation.service - Service für ioBroker Wetterstation Loaded: loaded (/etc/systemd/system/wetterstation.service; enabled; vendor preset: enabled) Active: failed (Result: exit-code) since Tue 2022-07-19 06:29:31 CEST; 11min ago Process: 12479 ExecStart=/home/latzi/wetterstation.sh (code=exited, status=1/FAILURE) Main PID: 12479 (code=exited, status=1/FAILURE) CPU: 7ms Jul 19 06:29:31 ioBroker wetterstation.sh[12479]: wetterstation: ERROR #000 - Config-Version mismatch! Jul 19 06:29:31 ioBroker wetterstation.sh[12479]: benutzt: V2.14.0 benötigt wird: V2.15.0EDIT: erledigt, hab die
wetterstation.confauf 2.15 geändert und nun läuft´s@latzi sagte in [Linux Shell-Skript] WLAN-Wetterstation:
Hast du eine Idee?
Sogar zwei, sind beides aber Fehler.
Weil er dynamisch den ws_updater von GitHub in der aktuellsten Version nach lädt, stimmt dann der (Installations-)Pfad nicht mehr:/dev/fd/wetterstation.confDann klappt auch das Update/Patch nicht ganz korrekt. Fixed in der nächsten Version/bzw. schon auf GitHub :heavy_check_mark:
influx hab ich gar nicht konfiguriert
Kpl. vergessen zu berücksichtigen, dass jemand ev. überhaupt kein Influx nutzt... Fixed in der nächsten Version :heavy_check_mark:
-
Dann mal eine kleine Roadmap was so aktuell in der Pipeline/noch geplant ist:
V2.16.0:
- Windrichtung ∅ der letzten 10 Minuten (für Stationen die dies nicht liefern)
- Windgeschwindigkeit ∅ der letzten 10 Minuten (für Stationen die dies nicht liefern)
V2.17.0:
- Windrichtung ∅- und Windgeschwindigkeit ∅ der letzten 10 Minuten alternativ anstelle der aktuellen Werte an OSeM, windy und wetter.com senden
- Temperaturtrend (Aussen, falls gewünscht auch Innen)
Die V2.16.0 ist soweit bereit für den Betatest, auch wenn mein gestriger Test um die Mittagszeit wenig erfolgversprechend verlief (Geschwindigkeit im Array | Anzahl im Array | Median(*) des Arrays):

(*)Median, damit nicht eine einzige stärkere Windböe sofort den 10-Minutenwert verfälschtLag aber eher an der Windflaute, der "Orkan" Abends hat die Funktionsfähigkeit dann aufgezeigt:

Na gut, waren wohl eher zwei oder drei Bienen die am Windmesser vorbei flogen... :joy:
zum zukünftigen Temperaturtrend in der V2.17.0:
- wie lange sollte der zu berücksichtigende Zeitraum sein? -1h oder mehr?
- als +/- Zahlenwert? So könnte man besser in der VIS/Grafana mappen und jeder kann sich den ev. anzuzeigenden Text selbst bestimmen.
- nur Außen- oder auch Innentemperatur?
-
@martybr Danke für das testen und es gibt auch so schon durchaus wichtigeres... ;)
...und ich sitze auch nicht rum und warte :)Der Fehler ist aber nicht in der Abfrage (vom fehlenden "=" mal abgesehen), sondern eher gedanklicher Natur. Die Abfrage kann so nur funktionieren wenn "ioB-Rechner" = "Rechner auf dem das Skript läuft" ist. Fixed mit der nächsten Version :heavy_check_mark:
Da in der V2.15.0 die Rest-API noch keinen Einsatz erfährt ist es nur ein kosmetisches/Anzeige Problemchen.
@sborg
So habe ich das auch gesehen. Ich hatte gestern Abend Zeit für das testen. Das Script arbeitet ja einwandfrei und ich bin sehr zufrieden.
Nur der Vollständigkeit halber:
Ich fahre 3 ioBroker Server und einen separaten Raspberry OHNE ioBroker, auf dem das Script läuft.
Wenn du weitere Test benötigt, dann helfe ich gerne.
Zu den Rechner (alle Debian Bullseye):- Master mit Influx V2 und Rest.api
- Slave mit Simple API
- Raspberry mit Script (ohne ioBroker)
-
@sborg
So habe ich das auch gesehen. Ich hatte gestern Abend Zeit für das testen. Das Script arbeitet ja einwandfrei und ich bin sehr zufrieden.
Nur der Vollständigkeit halber:
Ich fahre 3 ioBroker Server und einen separaten Raspberry OHNE ioBroker, auf dem das Script läuft.
Wenn du weitere Test benötigt, dann helfe ich gerne.
Zu den Rechner (alle Debian Bullseye):- Master mit Influx V2 und Rest.api
- Slave mit Simple API
- Raspberry mit Script (ohne ioBroker)
@martybr Gerne doch. Bin mir jetzt zwar sicher, aber testen kann ich es halt doch nicht.
Zuerst ein
RESTAPI_URL=https://1.2.3.4:12345auf dem PI bzw. Skript-Rechner
http oder https, IP des (bzw. eines auf dem die Rest-API läuft) ioB-Rechners und der benutzte Portdann (ist eine Befehlszeile):
if [[ $(iob status rest-api.0) =~ "is running" ]] || [[ $(nc -vz $(echo "${RESTAPI_URL}" | grep -o '[\.0-9]*')) =~ "succeeded" ]]; then echo API läuft; fiWenn du dann das Ganze nochmals mit gestoppter Rest-API ausführst sollte einfach gar nichts passieren.
-
@martybr Gerne doch. Bin mir jetzt zwar sicher, aber testen kann ich es halt doch nicht.
Zuerst ein
RESTAPI_URL=https://1.2.3.4:12345auf dem PI bzw. Skript-Rechner
http oder https, IP des (bzw. eines auf dem die Rest-API läuft) ioB-Rechners und der benutzte Portdann (ist eine Befehlszeile):
if [[ $(iob status rest-api.0) =~ "is running" ]] || [[ $(nc -vz $(echo "${RESTAPI_URL}" | grep -o '[\.0-9]*')) =~ "succeeded" ]]; then echo API läuft; fiWenn du dann das Ganze nochmals mit gestoppter Rest-API ausführst sollte einfach gar nichts passieren.
@sborg sagte in [Linux Shell-Skript] WLAN-Wetterstation:
if [[ $(iob status rest-api.0) =~ "is running" ]] || [[ $(nc -vz $(echo "${RESTAPI_URL}" | grep -o '[.0-9]*')) =~ "succeeded" ]]; then echo API läuft; fi
Hier der Test mit laufender Rest.api:
martin@tinkerboard:~$ RESTAPI_URL=https://192.168.178.100:8093 martin@tinkerboard:~$ RESTAPI_URL=http://192.168.178.100:8093 martin@tinkerboard:~$ if [[ $(iob status rest-api.0) =~ "is running" ]] || [[ $(nc -vz $(echo "${RESTAPI_URL}" | grep -o '[\.0-9]*')) =~ "succeeded" ]]; then echo API läuft; fi Command 'iob' not found, did you mean: command 'iog' from deb iog command 'irb' from deb ruby command 'wob' from deb wob Try: sudo apt install <deb name> Connection to 192.168.178.100 8093 port [tcp/*] succeeded! martin@tinkerboard:~$Nun mit gestoppter Rest.api:
martin@tinkerboard:~$ RESTAPI_URL=http://192.168.178.100:8093 martin@tinkerboard:~$ if [[ $(iob status rest-api.0) =~ "is running" ]] || [[ $(nc -vz $(echo "${RESTAPI_URL}" | grep -o '[\.0-9]*')) =~ "succeeded" ]]; then echo API läuft; fi Command 'iob' not found, did you mean: command 'irb' from deb ruby command 'wob' from deb wob command 'iog' from deb iog Try: sudo apt install <deb name> ^C martin@tinkerboard:~$ -
Dann mal eine kleine Roadmap was so aktuell in der Pipeline/noch geplant ist:
V2.16.0:
- Windrichtung ∅ der letzten 10 Minuten (für Stationen die dies nicht liefern)
- Windgeschwindigkeit ∅ der letzten 10 Minuten (für Stationen die dies nicht liefern)
V2.17.0:
- Windrichtung ∅- und Windgeschwindigkeit ∅ der letzten 10 Minuten alternativ anstelle der aktuellen Werte an OSeM, windy und wetter.com senden
- Temperaturtrend (Aussen, falls gewünscht auch Innen)
Die V2.16.0 ist soweit bereit für den Betatest, auch wenn mein gestriger Test um die Mittagszeit wenig erfolgversprechend verlief (Geschwindigkeit im Array | Anzahl im Array | Median(*) des Arrays):

(*)Median, damit nicht eine einzige stärkere Windböe sofort den 10-Minutenwert verfälschtLag aber eher an der Windflaute, der "Orkan" Abends hat die Funktionsfähigkeit dann aufgezeigt:

Na gut, waren wohl eher zwei oder drei Bienen die am Windmesser vorbei flogen... :joy:
zum zukünftigen Temperaturtrend in der V2.17.0:
- wie lange sollte der zu berücksichtigende Zeitraum sein? -1h oder mehr?
- als +/- Zahlenwert? So könnte man besser in der VIS/Grafana mappen und jeder kann sich den ev. anzuzeigenden Text selbst bestimmen.
- nur Außen- oder auch Innentemperatur?
@sborg said in [Linux Shell-Skript] WLAN-Wetterstation:
Dann mal eine kleine Roadmap was so aktuell in der Pipeline/noch geplant ist:
V2.16.0:
- Windrichtung ∅ der letzten 10 Minuten (für Stationen die dies nicht liefern)
- Windgeschwindigkeit ∅ der letzten 10 Minuten (für Stationen die dies nicht liefern)
V2.17.0:
- Windrichtung ∅- und Windgeschwindigkeit ∅ der letzten 10 Minuten alternativ anstelle der aktuellen Werte an OSeM, windy und wetter.com senden
- Temperaturtrend (Aussen, falls gewünscht auch Innen)
Die V2.16.0 ist soweit bereit für den Betatest, auch wenn mein gestriger Test um die Mittagszeit wenig erfolgversprechend verlief (Geschwindigkeit im Array | Anzahl im Array | Median(*) des Arrays):

(*)Median, damit nicht eine einzige stärkere Windböe sofort den 10-Minutenwert verfälschtLag aber eher an der Windflaute, der "Orkan" Abends hat die Funktionsfähigkeit dann aufgezeigt:

Na gut, waren wohl eher zwei oder drei Bienen die am Windmesser vorbei flogen... :joy:
zum zukünftigen Temperaturtrend in der V2.17.0:
- wie lange sollte der zu berücksichtigende Zeitraum sein? -1h oder mehr?
- als +/- Zahlenwert? So könnte man besser in der VIS/Grafana mappen und jeder kann sich den ev. anzuzeigenden Text selbst bestimmen.
- nur Außen- oder auch Innentemperatur?
Die Roadmap klingt gut :+1:
Zum Temperaturtrend:
+/- Zahlenwert würde ich auch begrüßen
Beim Zeitraum bin ich mir auch nicht so sicher, was da sinnvoll wäre.
Bei den Geräten wäre es vielleicht noch für den/die DP50 sinnvoll, könnte ja dann in den entsprechenden Objektbaum vom DP50 mit rein. -
@sborg sagte in [Linux Shell-Skript] WLAN-Wetterstation:
if [[ $(iob status rest-api.0) =~ "is running" ]] || [[ $(nc -vz $(echo "${RESTAPI_URL}" | grep -o '[.0-9]*')) =~ "succeeded" ]]; then echo API läuft; fi
Hier der Test mit laufender Rest.api:
martin@tinkerboard:~$ RESTAPI_URL=https://192.168.178.100:8093 martin@tinkerboard:~$ RESTAPI_URL=http://192.168.178.100:8093 martin@tinkerboard:~$ if [[ $(iob status rest-api.0) =~ "is running" ]] || [[ $(nc -vz $(echo "${RESTAPI_URL}" | grep -o '[\.0-9]*')) =~ "succeeded" ]]; then echo API läuft; fi Command 'iob' not found, did you mean: command 'iog' from deb iog command 'irb' from deb ruby command 'wob' from deb wob Try: sudo apt install <deb name> Connection to 192.168.178.100 8093 port [tcp/*] succeeded! martin@tinkerboard:~$Nun mit gestoppter Rest.api:
martin@tinkerboard:~$ RESTAPI_URL=http://192.168.178.100:8093 martin@tinkerboard:~$ if [[ $(iob status rest-api.0) =~ "is running" ]] || [[ $(nc -vz $(echo "${RESTAPI_URL}" | grep -o '[\.0-9]*')) =~ "succeeded" ]]; then echo API läuft; fi Command 'iob' not found, did you mean: command 'irb' from deb ruby command 'wob' from deb wob command 'iog' from deb iog Try: sudo apt install <deb name> ^C martin@tinkerboard:~$@martybr Danke, geht aber auch nicht in allen Fällen :(
Die Version funktioniert nun:
RESTAPI_URL=https://192.168.1.3:8093 if [ "$(nc -vz $(echo "${RESTAPI_URL}" | grep -o '[\.0-9]*') &> /dev/null; echo $?)" -eq "0" ]; then echo Heureka; fi -
@martybr Danke, geht aber auch nicht in allen Fällen :(
Die Version funktioniert nun:
RESTAPI_URL=https://192.168.1.3:8093 if [ "$(nc -vz $(echo "${RESTAPI_URL}" | grep -o '[\.0-9]*') &> /dev/null; echo $?)" -eq "0" ]; then echo Heureka; fi@sborg sagte in [Linux Shell-Skript] WLAN-Wetterstation:
if [ "$(nc -vz $(echo "${RESTAPI_URL}" | grep -o '[.0-9]*') &> /dev/null; echo $?)" -eq "0" ]; then echo Heureka; fi
Ich habe die Befehle auf dem Script-Server gestartet und kann Heureka zurückmelden:
martin@tinkerboard:~$ RESTAPI_URL=http://192.168.178.100:8093 martin@tinkerboard:~$ if [ "$(nc -vz $(echo "${RESTAPI_URL}" | grep -o '[\.0-9]*') &> /dev/null; echo $?)" -eq "0" ]; then echo Heureka; fi Heureka martin@tinkerboard:~$ -
@sborg said in [Linux Shell-Skript] WLAN-Wetterstation:
Dann mal eine kleine Roadmap was so aktuell in der Pipeline/noch geplant ist:
V2.16.0:
- Windrichtung ∅ der letzten 10 Minuten (für Stationen die dies nicht liefern)
- Windgeschwindigkeit ∅ der letzten 10 Minuten (für Stationen die dies nicht liefern)
V2.17.0:
- Windrichtung ∅- und Windgeschwindigkeit ∅ der letzten 10 Minuten alternativ anstelle der aktuellen Werte an OSeM, windy und wetter.com senden
- Temperaturtrend (Aussen, falls gewünscht auch Innen)
Die V2.16.0 ist soweit bereit für den Betatest, auch wenn mein gestriger Test um die Mittagszeit wenig erfolgversprechend verlief (Geschwindigkeit im Array | Anzahl im Array | Median(*) des Arrays):

(*)Median, damit nicht eine einzige stärkere Windböe sofort den 10-Minutenwert verfälschtLag aber eher an der Windflaute, der "Orkan" Abends hat die Funktionsfähigkeit dann aufgezeigt:

Na gut, waren wohl eher zwei oder drei Bienen die am Windmesser vorbei flogen... :joy:
zum zukünftigen Temperaturtrend in der V2.17.0:
- wie lange sollte der zu berücksichtigende Zeitraum sein? -1h oder mehr?
- als +/- Zahlenwert? So könnte man besser in der VIS/Grafana mappen und jeder kann sich den ev. anzuzeigenden Text selbst bestimmen.
- nur Außen- oder auch Innentemperatur?
Die Roadmap klingt gut :+1:
Zum Temperaturtrend:
+/- Zahlenwert würde ich auch begrüßen
Beim Zeitraum bin ich mir auch nicht so sicher, was da sinnvoll wäre.
Bei den Geräten wäre es vielleicht noch für den/die DP50 sinnvoll, könnte ja dann in den entsprechenden Objektbaum vom DP50 mit rein.@viper4iob sagte in [Linux Shell-Skript] WLAN-Wetterstation:
Die Roadmap klingt gut
...und wie das so mit Plänen ist...
Eigentlich wollte ich die 16er schon in den öffentlichen Beta-Test schicken, dann habe ich den ganzen Morgen bis eben damit verbracht~ Bugfix gelegentlicher "jq parse"-Fehler ~ Bugfix Regenmenge des meteorologischen Sommers aktualisiert sich nichtGerade #2 war "extrem lustig". Von Hand per
./wetterstation.sh --metsommerfunktioniert es, und obwohl er als Service genau das Gleiche macht geht es dann nicht ?!?Ich habe schon für mein Büro eine Trendanzeige. IMO mehr als 1h ist eher Weissagung per Glaskugel als denn ein halbwegs fundierter Trend.
"Außentemperatur" hat jeder, aber wie sieht es mit der "Innentemperatur" aus? Nicht jeder hat wieder ein Display, dann gibt es wieder verschiedene Zusatzsensoren, verschiedene Anzahl an Sensoren. Will man das überhaupt für alle Sensoren... Macht es nicht gerade leichter.
Ich würde es dann wohl auf den reinen Innentemperatursensor begrenzen. -
@sborg sagte in [Linux Shell-Skript] WLAN-Wetterstation:
if [ "$(nc -vz $(echo "${RESTAPI_URL}" | grep -o '[.0-9]*') &> /dev/null; echo $?)" -eq "0" ]; then echo Heureka; fi
Ich habe die Befehle auf dem Script-Server gestartet und kann Heureka zurückmelden:
martin@tinkerboard:~$ RESTAPI_URL=http://192.168.178.100:8093 martin@tinkerboard:~$ if [ "$(nc -vz $(echo "${RESTAPI_URL}" | grep -o '[\.0-9]*') &> /dev/null; echo $?)" -eq "0" ]; then echo Heureka; fi Heureka martin@tinkerboard:~$@martybr sagte in [Linux Shell-Skript] WLAN-Wetterstation:
und kann Heureka zurückmelden
Ich fand immer "API läuft" langweilig :joy:
...aber es geht zumindest 8) -
@martybr sagte in [Linux Shell-Skript] WLAN-Wetterstation:
und kann Heureka zurückmelden
Ich fand immer "API läuft" langweilig :joy:
...aber es geht zumindest 8) -
Tests heute Nacht erfolgreich abgeschlossen 8)
Neue Beta-Version des Wetterstation WLAN-Skriptes auf GitHub V2.16.0
(Beta-Releases lassen sich nicht! über den ws_updater.sh installieren, nur die *.conf lässt sich mit dem ws_updater.beta ggf. patchen [s.u.])
- + Windrichtung der letzten 10 Minuten für alle Stationen (benötigt wird dafür nun noch 'dc')
- + durchschnittliche Windgeschwindigkeit der letzten 10 Minuten für alle Stationen
- ~ Bugfix gelegentlicher "jq parse"-Fehler
- ~ Bugfix Regenmenge des meteorologischen Sommers aktualisiert sich nicht
Wie immer zu finden im GitHub
Update-Routine:
- wetterstation.sh, wetterstation.sub und ws_updater.beta (muss "ausführbar" sein
chmod +x ws_updater.beta) ersetzen bzw. kopieren ./ws_updater.beta --patchim Installationsverzeichnis ausführen und ev. Hinweise beachten- nun mittels
[sudo] systemctl restart wetterstationden Service neu starten
Liefert die Station bereits die beiden 10 Minuten-Werte werden diese benutzt, ansonsten berechnet sie das Skript. Um Ausreißer durch Windböen zu minimieren, wird die Windgeschwindigkeit Median berechnet.
Die "10 Minuten" sind dabei nicht ganz richtig und sind eher "10 Minuten +/- xx Sekunden", da hier der Einfachheit halber die letzten 20 Messwerte heran gezogen werden.