NEWS
[Linux Shell-Skript] WLAN-Wetterstation
-
pi@raspberrypi:~ $ mv /home/iobroker/wetterstation* /home/pi/wetterstation mv: das Verschieben von '/home/iobroker/wetterstation.conf' nach '/home/pi/wetterstation/wetterstation.conf' ist nicht möglich: Keine Berechtigung mv: das Verschieben von '/home/iobroker/wetterstation.sh' nach '/home/pi/wetterstation/wetterstation.sh' ist nicht möglich: Keine Berechtigung mv: das Verschieben von '/home/iobroker/wetterstation.sub' nach '/home/pi/wetterstation/wetterstation.sub' ist nicht möglich: Keine Berechtigung
-
@Thomas-Braun Kann ich gerade nicht so nachvollziehen.
pi@raspberrypi:~/weather $ ls -la total 136 drwxr-xr-x 3 pi pi 4096 Jan 4 00:00 . drwxr-xr-x 4 pi pi 4096 Jan 2 10:37 .. -rw-r--r-- 1 root root 9377 Jan 3 23:59 20220103_station.log -rw-r--r-- 1 root root 1594 Jan 4 14:38 20220104_station.log drwxr-xr-x 2 pi pi 4096 Jan 3 15:25 Version:2.10.1 -rw-r--r-- 1 pi pi 6075 Jan 3 15:43 wetterstation.conf -rwxr--r-- 1 pi pi 15867 Jan 3 15:03 wetterstation.sh -rw-r--r-- 1 pi pi 65396 Jan 3 15:45 wetterstation.sub -rwxr--r-- 1 pi pi 16659 Jan 3 15:05 ws_updater.sh
Das Script läuft doch als pi.
-
@gezi70 sagte in [Linux Shell-Skript] WLAN-Wetterstation:
/home/pi/wetterstation
ls -la /home/pi/wetterstation
-
@thomas-braun läuft jetzt, danke
-
-
@thomas-braun Ich habs gerade gesehen. Im HTOP wird das Script als root ausgeführt - das erklärt die Ablage der neuen Files als root. Dann muss bei der Erstellung des systemd was falsch sein - nur was?
Irgendwo muss ein Knoten sein. Starte ich das Script von Hand läuft es als pi - beim Schreiben des Logfiles gibt es dann 'Permission denied'. -
@rene55 That's my fault
Geändert habe ich es schon lange, aber irgendwie vergessen zu kommunizieren. Der systemd lädt beim booten den Service per default unter "root".
Deswegen habe ich im ws_updater den Service so anlegen lassen:[Unit] Description=Service für ioBroker Wetterstation [Service] User=$(whoami) Group=$(whoami) ExecStart=${DIR}/wetterstation.sh [Install] WantedBy=multi-user.target
whoami ("wer_bin_ich") wird dabei durch den aktuell angemeldeten Usernamen ersetzt.
Muss ich wohl hier einen Mini-Patch bereitstellen der es patcht, oder ihr (betrifft alle, außer diejenigen die den Service mittels ws_updater anlegen ließen) editiert es selbst hinein:sudo nano /etc/systemd/system/wetterstation.service
Dann unter "Service" die beiden ZeilenUser= Group=
ergänzen und mit eurem Loginnamen befüllen und speichern.
Service restarten:systemctl restart wetterstation
Dann läuft es im User-Kontext.
Eben noch geändert: siehe WiKi (fast ganz unten) -
@sborg Super. Gefixt, Script läuft als 'pi' und schreibt auch Logs als 'pi'. Mercy
-
Mit was für ein Editor öffne ich das ?
Das war´s auch schon mit der Konfiguration des Skriptes. Anlegen der Datenobjekte im ioBroker: Wir öffnen wetterstation.js aus dem Paket mit einem Texteditor, kopieren uns den gesamten Inhalt in die Zwischenablage und wechseln zum ioBroker. Dort wählen wir "Skripte" und legen per Klick auf das "+" ein neues Javascript vom Typ "Javascript" an. Speicherort (unter common) und Bezeichnung sind frei wählbar. In dieses leere Skript fügen wir nun den Inhalt der Zwischenablage ein. Falls eine andere Instanz des Javascript-Adapters oder eine andere Datenobjektstruktur benutzt wird, muss noch let DP="javascript.0.Wetterstation." angepasst (identische Einstellung wie in der wetterstation.conf unter PRE_DP) werden. Beachtet unbedingt den Punkt hinter "Wetterstation"! Falls das Gateway und/oder Zusatzsensoren (DP40/50/60/70/100/200/250/300 bzw. deren WHxxx-Derivate) benutzt werden muss deren Anzahl nun noch eingetragen werden.
-
nano
ist vermutlich der einfachste Editor auf Kommandozeile. -
@thomas-braun sagte in [Linux Shell-Skript] WLAN-Wetterstation:
nano
ist vermutlich der einfachste Editor auf Kommandozeile.Dann müsstw ich die Skriptdatei (wetterstation.js)auch in den Ordner verschieben?
-
@andre105 Irgendein Verzeichnis im /home des users. Der Pfad dorthin wird ja in der service-Datei angegeben.
-
Habe den Skript angelegt,gestartet und wieder gestoppt.
Jetzt in Putty den Befehl ausgefürt.
andre105@iobroker:~/wetter$ ./wetterstation.sh --debug wetterstation: ERROR #000 - Config-Version mismatch! benutzt: Settings benötigt wird: V2.10.0 andre105@iobroker:~/wetter$
Was ist das für ein Fehler?
-
@andre105 sagte in [Linux Shell-Skript] WLAN-Wetterstation:
benutzt: Settings benötigt wird: V2.10.0
Du hast offenbar die 1. Zeile der wetterstation.conf etwas verwurstelt. Die darf keinesfalls verändert werden, da hierüber geprüft wird ob die Versionen der Dateien zueinander passen.
In deinem Wetter-Verzeichnis:head -n 1 wetterstation.conf
Dann muss das dabei herauskommen (Format und Leerzeichen sind wichtig) :
### Settings V2.10.0 -----------------------------------------------------------
-
@sborg sagte in [Linux Shell-Skript] WLAN-Wetterstation:
@andre105 sagte in [Linux Shell-Skript] WLAN-Wetterstation:
benutzt: Settings benötigt wird: V2.10.0
Du hast offenbar die 1. Zeile der wetterstation.conf etwas verwurstelt. Die darf keinesfalls verändert werden, da hierüber geprüft wird ob die Versionen der Dateien zueinander passen.
In deinem Wetter-Verzeichnis:head -n 1 wetterstation.conf
Dann muss das dabei herauskommen (Format und Leerzeichen sind wichtig) :
### Settings V2.10.0 -----------------------------------------------------------
Ja stimmt.
Jetzt kam dieses bei raus.
WLAN-Wetterstation V2.10.1 - (c)2019-2021 by SBorg Config-Version: V2.10.0 Sub-Version : V2.10.1 'bc' installiert: [✓] 'jq' installiert: [✓] [sudo] Passwort für andre105: ┌────────────────────────────────────────────────────────────┐ │ │ │ "netcat" ist nicht in der benötigten Version installiert! │ │ │ │ Soll er nun installiert werden? [J/N]: j │ │ │ └────────────────────────────────────────────────────────────┘ Paketlisten werden gelesen… Fertig Abhängigkeitsbaum wird aufgebaut… Fertig Statusinformationen werden eingelesen… Fertig Die folgenden NEUEN Pakete werden installiert: netcat-openbsd 0 aktualisiert, 1 neu installiert, 0 zu entfernen und 14 nicht aktualisiert. Es müssen 41,1 kB an Archiven heruntergeladen werden. Nach dieser Operation werden 114 kB Plattenplatz zusätzlich benutzt. Holen:1 http://ftp.de.debian.org/debian bullseye/main amd64 netcat-openbsd amd64 1.217-3 [41,1 kB] Es wurden 41,1 kB in 0 s geholt (104 kB/s). Vormals nicht ausgewähltes Paket netcat-openbsd wird gewählt. (Lese Datenbank ... 43532 Dateien und Verzeichnisse sind derzeit installiert.) Vorbereitung zum Entpacken von .../netcat-openbsd_1.217-3_amd64.deb ... Entpacken von netcat-openbsd (1.217-3) ... netcat-openbsd (1.217-3) wird eingerichtet ... update-alternatives: /bin/nc.openbsd wird verwendet, um /bin/nc (nc) im automatischen Modus bereitzustellen Trigger für man-db (2.9.4-2) werden verarbeitet ... Connection to 192.168.178.64 8087 port [tcp/*] succeeded!
WLAN-Wetterstation V2.10.1 - (c)2019-2021 by SBorg Config-Version: V2.10.0 Sub-Version : V2.10.1 'bc' installiert: [✓] 'jq' installiert: [✓] 'nc' in der Openbsd-Variante installiert: [✓] 'netcat' in Openbsd-Variante aktiv, alles korrekt [✓] Connection to 192.168.178.64 8087 port [tcp/*] succeeded! Messwerteblock: Nicht alle Werte werden unterstützt (abhängig vom Modell der Wetterstation und dem verwendeten Protokol l)! Temperatur Innen : °C Temperatur Aussen : °C Taupunkt : °C Gefühlte Temperatur : °C Luftfeuchte Innen : % Luftfeuchte Aussen : % Windgeschwindkeit : km/h Windböengeschwindkeit : 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/andre105/wetter IPP: 192.168.178.64:8087 WS_PORT: 6969 WS_POLL: 30 PRE_DP: javascript.0.We tterstation WEB: HTTP WS_PROT: Ecowitt DP40/50/60/70/100/200/250/300: 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 WH31: 0 Script-Version: V2.10.1 Config-Version: V2.10.0 Sub-Version: V2.10.1 Kommunikationsfehler! andre105@iobroker:~/wetter$
-
@thomas-braun Ich habe mal wieder drin rum gemehrt und nichts geht mehr:
Ich wollte ein anderes Verzeichnis in /home/pi anlegen und habe die Dateien dort hinein kopiert.
Nach Anpassen der ExecStart Datei auf den neuen Pfad findet das system trotz der genauen Angabe die Datei wetterstation.sh nicht. Es kommen keine Daten mehr rein... Wie kann ich nochmal von vorne anfangen?pi@raspberrypi:~ $ ./wetterstation.sh --data -bash: ./wetterstation.sh: Datei oder Verzeichnis nicht gefunden
und beim Ausführen im Verzeichnis:
pi@raspberrypi:~/Wetterscript $ ./wetterstation.sh --data -bash: ./wetterstation.sh: Keine Berechtigung
-
Jetzt geht es wieder. Ich hatte vergessen den TCP Port in der Config einzutragen. Dann kanns auch nicht gehen...
-
@sborg Danke für die hilfe,
zu 1.) Es hat geholfen auf Default zu stellen, hiernach hab ich die Messwerte bekommen.
2.) Danke für das Skript, funktioniert.
3.) Ich ersuche die Werte über Blockly auf die Alias Datenpunkt umzulegen. Man hat aber hier ja nur mit den Wissen die Info das es für die Abfrage von Windy und Opensensmap ist.
4.) Danke für das Skript, funktioniert.
Zu den Hintergrundbilder:
Leider konnte ich durch Grafana Contianer nicht dirket auf den Pfad zugreifen. Ich habe dann den Pfad /var/lib/grafana ausgelagert. Diese ientspricht aber nicht den Pfad ausden Skript und ich finde das Panel nicht bzw. wenn ich eine neues einfüge verschiebt sich alles.
Ich habe nun die Bilder unter /docker/grafana/plugins/yesoreyeram-boomtheme-panel/img/Wetter abgelegt. Folgendes Fehlerbild hat sich ergeben ich finde aber nicht die Einstellungen für den Pfad. (siehe Bild unten)Pimpmystation:
Sehr Interessant, onedrop Regen fände ich sehr wichtig. -
Hi,
wollte gerade per ws_updater meine Scripte aktualisieren, dabei ist dann das heraus gekommen:
pi@pi-iobroker:~/wetterstation $ ./ws_updater.sh ┌────────────────────────┐ │ │ │ WS-Updater V2.11.0 │ │ │ └────────────────────────┘ 'bc' installiert: [✓] 'jq' installiert: [✓] 'unzip' installiert: [✓] 'patch' installiert: [✓] Aktuelle Version (latest) auf GitHub: V2.11.0 vom 03.12.2021 Version im aktuellen Verzeichnis : V2.5.0 Informationen zum Release V2.11.0: ───────────────────────────────────────────────────────────── Neu/Änderungen im Release: ~ Windgeschwindigkeit bei wetter.com in m/s + Konfigurationsmöglichkeit des Kommunikationsfehlers (Issue #26) ~ Bugfix Speicherort beim logging ~ Ergänzung bei Prüfung auf valides Datenpaket (Außentemperatur hinzugefügt) + Hinweis auf korrekte WS_ID bei Wunderground-Protokoll falls Kommunikationsfehler Soll ein Update von WLAN-Wetterstation durchgeführt werden? [J/N]: J Führe Update aus... % Total % Received % Xferd Average Speed Time Time Time Current Dload Upload Total Spent Left Speed 100 661 100 661 0 0 2633 0 --:--:-- --:--:-- --:--:-- 2633 100 29761 100 29761 0 0 52120 0 --:--:-- --:--:-- --:--:-- 52120 Archive: tmp.zip alle n▒tigen Dateien des Projektes inflating: ws_updater.sh inflating: wetterstation.js inflating: wetterstation.sh inflating: wetterstation.sub ┌────────────────────────┐ │ │ │ WS-Updater V2.11.0 │ │ │ └────────────────────────┘ Soll die wetterstation.conf nun auf eine neue Version gepatcht werden? [J/N]: j Lege Sicherungskopie der wetterstation.conf an... Patche wetterstation.conf auf V2.6.0 ... patching file ./wetterstation.conf Hunk #2 FAILED at 112. 1 out of 2 hunks FAILED -- saving rejects to file ./wetterstation.conf.rej Windy kann nun mittels ./wetterstation.sh --windy_reg eingerichtet werden ! Update ausgeführt. Soll der Service nun neu gestartet werden? [J/N]: j
Warum hat er die Conf von 2.5.0 auf 2.6.0 updaten den Rest aber direkt auf 2.11 ?
Ergebnis:
pi@pi-iobroker:~/wetterstation $ systemctl status wetterstation.service ● wetterstation.service - Service für ioBroker Wetterstation Loaded: loaded (/etc/systemd/system/wetterstation.service; enabled; vendor preset: enabled) Active: failed (Result: exit-code) since Wed 2022-01-05 08:22:59 CET; 3s ago Process: 4188 ExecStart=/home/pi/wetterstation/wetterstation.sh (code=exited, status=1/FAILURE) Main PID: 4188 (code=exited, status=1/FAILURE) Jan 05 08:22:59 pi-iobroker systemd[1]: Started Service für ioBroker Wetterstation. Jan 05 08:22:59 pi-iobroker wetterstation.sh[4188]: wetterstation: ERROR #000 - Config-Version mismatch! Jan 05 08:22:59 pi-iobroker wetterstation.sh[4188]: benutzt: V2.6.0 benötigt wird: V2.11.0 Jan 05 08:22:59 pi-iobroker systemd[1]: wetterstation.service: Main process exited, code=exited, status=1/FAILURE Jan 05 08:22:59 pi-iobroker systemd[1]: wetterstation.service: Failed with result 'exit-code'.
Wenn ich den Updater erneut starte sagt er mir nur alles sei aktuell.
EDIT: Habe die Conf Datei jetzt manuell aktualisiert und wollte somit nur auf den möglichen Bug hinweisen.
Vielleicht hat in diesem Zusammenhang noch jemand eine Idee zu diesem Problem: Hilfe zu Grafana
-
@andre105 sagte in [Linux Shell-Skript] WLAN-Wetterstation:
Zeile #68| Kommunikationsfehler!
Du bekommst von dem Rechner auf dem das Skript läuft keine Verbindung zur Wetterstation bzw. diese sendet nichts an diesen Rechner.
Unter der Annahme, dass dein ioB-Rechner auch der ist auf dem das Skript läuft (IP x.x.x.64) und der Log-Ausgabe, müsstest du per WS View in der Station die IP 192.168.178.64 und den Port 6969 eingetragen haben?