NEWS
[Linux Shell-Skript] WLAN-Wetterstation
-
@sborg sagte in [Linux Shell-Skript] WLAN-Wetterstation:
Fällt dir bei 'bc' und 'jq' etwas auf?
bc
jqaber noch Fehler
root@Webserver:~/wetter# bash <(curl -s https://raw.githubusercontent.com/SBorg2014/WLAN-Wetterstation/master/ws_updater.sh) --install ┌───────────────────────┐ │ │ │ WS-Updater V2.9.0 │ │ │ └───────────────────────┘ 'bc' installiert: [✗] Bitte zuerst 'bc' installieren [sudo apt install bc] root@Webserver:~/wetter# sudo apt install bc sudo: setrlimit(RLIMIT_CORE): Operation not permitted Reading package lists... Done Building dependency tree Reading state information... Done The following NEW packages will be installed: bc 0 upgraded, 1 newly installed, 0 to remove and 151 not upgraded. Need to get 86.3 kB of archives. After this operation, 231 kB of additional disk space will be used. Get:1 http://archive.ubuntu.com/ubuntu focal/main amd64 bc amd64 1.07.1-2build1 [86.3 kB] Fetched 86.3 kB in 0s (175 kB/s) Selecting previously unselected package bc. (Reading database ... 17495 files and directories currently installed.) Preparing to unpack .../bc_1.07.1-2build1_amd64.deb ... Unpacking bc (1.07.1-2build1) ... Setting up bc (1.07.1-2build1) ... Processing triggers for install-info (6.7.0.dfsg.2-5) ... Processing triggers for man-db (2.9.1-1) ... root@Webserver:~/wetter# bash <(curl -s https://raw.githubusercontent.com/SBorg2014/WLAN-Wetterstation/master/ws_updater.sh) --install ┌───────────────────────┐ │ │ │ WS-Updater V2.9.0 │ │ │ └───────────────────────┘ 'bc' installiert: [✓] 'jq' installiert: [✗] Bitte zuerst 'jq' installieren [sudo apt install jq] root@Webserver:~/wetter# sudo apt install jq sudo: setrlimit(RLIMIT_CORE): Operation not permitted Reading package lists... Done Building dependency tree Reading state information... Done The following additional packages will be installed: libjq1 libonig5 The following NEW packages will be installed: jq libjq1 libonig5 0 upgraded, 3 newly installed, 0 to remove and 151 not upgraded. Need to get 313 kB of archives. After this operation, 1062 kB of additional disk space will be used. Do you want to continue? [Y/n] Y Get:1 http://archive.ubuntu.com/ubuntu focal/universe amd64 libonig5 amd64 6.9.4-1 [142 kB] Get:2 http://archive.ubuntu.com/ubuntu focal-updates/universe amd64 libjq1 amd64 1.6-1ubuntu0.20.04.1 [121 kB] Get:3 http://archive.ubuntu.com/ubuntu focal-updates/universe amd64 jq amd64 1.6-1ubuntu0.20.04.1 [50.2 kB] Fetched 313 kB in 0s (885 kB/s) Selecting previously unselected package libonig5:amd64. (Reading database ... 17512 files and directories currently installed.) Preparing to unpack .../libonig5_6.9.4-1_amd64.deb ... Unpacking libonig5:amd64 (6.9.4-1) ... Selecting previously unselected package libjq1:amd64. Preparing to unpack .../libjq1_1.6-1ubuntu0.20.04.1_amd64.deb ... Unpacking libjq1:amd64 (1.6-1ubuntu0.20.04.1) ... Selecting previously unselected package jq. Preparing to unpack .../jq_1.6-1ubuntu0.20.04.1_amd64.deb ... Unpacking jq (1.6-1ubuntu0.20.04.1) ... Setting up libonig5:amd64 (6.9.4-1) ... Setting up libjq1:amd64 (1.6-1ubuntu0.20.04.1) ... Setting up jq (1.6-1ubuntu0.20.04.1) ... Processing triggers for man-db (2.9.1-1) ... Processing triggers for libc-bin (2.31-0ubuntu9) ... root@Webserver:~/wetter# bash <(curl -s https://raw.githubusercontent.com/SBorg2014/WLAN-Wetterstation/master/ws_updater.sh) --install ┌───────────────────────┐ │ │ │ WS-Updater V2.9.0 │ │ │ └───────────────────────┘ 'bc' installiert: [✓] 'jq' installiert: [✓] Möchten Sie WLAN-Wetterstation im aktuellen Verzeichnis installieren? [J/N]: J Hole Daten von GitHub... Aktuelle Version: V2.9.0 vom 25.08.2021 Lade Datei von GitHub herunter... % Total % Received % Xferd Average Speed Time Time Time Current Dload Upload Total Spent Left Speed 100 630 100 630 0 0 2316 0 --:--:-- --:--:-- --:--:-- 2316 100 35355 100 35355 0 0 64871 0 --:--:-- --:--:-- --:--:-- 663k Entpacke Dateien... /dev/fd/63: line 318: unzip: command not found Lösche Dateidownload... Dateien ausführbar setzen... chmod: cannot access 'ws_updater.sh': No such file or directory chmod: cannot access 'wetterstation.sh': No such file or directory Soll WLAN-Wetterstation nun als Service eingerichtet werden? [J/N]: J Wetterstation-Service existiert bereits! Konfiguration nun öffnen? [J/N]: Jcat: /root/.selected_editor: No such file or directory /dev/fd/63: line 331: wetterstation.conf: command not found Nun mittels des Javascriptes 'wetterstation.js' die Datenpunkte im ioBroker anlegen! Fertig [ Nein=Abbruch ]? [J/N]: J/dev/fd/63: line 339: jn_abfrage\n\e[1;37m Einmaligen Testdurchlauf im Debug-Modus starten...(empfiehlt sich)?: command not found /dev/fd/63: line 340: ./wetterstation.sh: No such file or directory /dev/fd/63: line 343: jn_abfrage\n\e[1;37m WLAN-Wetterstation Service nun starten?: command not found sudo: setrlimit(RLIMIT_CORE): Operation not permitted Fertig... Wenn der Testlauf ausgeführt wurde und erfolgreich verlief, sollten nun aktuelle Daten der Wetterstation in den Datenpunkten stehen ;-)
-
@negalein sagte in [Linux Shell-Skript] WLAN-Wetterstation:
/dev/fd/63: line 318: unzip: command not found
Ok, da muss ich noch prüfen ob 'unzip' installiert ist, aber nu erst mal zu Abend spachteln gehen
Dachte eigentlich zumindest dass wäre standardmäßig installiert. -
@sborg sagte in [Linux Shell-Skript] WLAN-Wetterstation:
aber nu erst mal zu Abend spachteln gehen
Mahlzeit
-
@negalein Danke, Rest vom Mittagessen
...new version Online...bin aber für Heute raus, läute jetzt den Fernsehabend ein
-
@sborg nu, bei mich sagts:
bascht das so? -
@sborg sagte in [Linux Shell-Skript] WLAN-Wetterstation:
..new version Online
weiter gehts auf der Test-VM
Ich komme bis hier
Mit
J
bestätigtDann kommt das
und steht bis dann irgendwann das kommt (vermutlich, weil ich wegen obigem Fehler nicht in die Konfig komme
-
Ich plane mir eine Froggit HP1000SE Pro anzuschaffen.
Ein Grund dafür ist unter anderem das super Wetterstations-Skript hier, um die Daten in den iobroker zu bekommen.Jetzt habe ich die ganze Historie des Skripts nicht mitbekommen, wenn ich es aber richtig verstanden habe, fängt das Skript die Daten der Wetterstation per netcat ab und pumpt sie mittels curl über den Simple RESTful API Adapter in den iobroker.
Das Skript ist ja ein Shell-Skript und es gibt das Shell-Kommando "iobroker state set <id> <value> [<ack>]", um Datenpunkte im iobroker zu setzen.
Jetzt stellt sich die naheliegende Frage, ob es nicht Sinn machen würde das Shell-Kommando statt dem curl-Aufruf zu nutzen. Dann wäre man auch unabhängig von einem zusätzlichen Adapter.
Gibt es da einen bestimmten Grund oder ist es historisch einfach so gewachsen?Und ich hätte noch eine zweite Frage:
Ich nutze aktuell den MySQL Adapter, um historische Daten im iobroker zu sammeln, weil ich MySQL für anderen Themen eh schon am laufen hatte.
Gibt es eine Chance das Wetterstatistik Skript zu erweitern, so dass man auch die Daten aus MySQL nutzen könnte?
Man kann die Daten ähnlich wie bei der InfluxDB in Javascript auch mittels sendTo abfragen, Beispiel:sendTo('sql.0', 'query', 'SELECT id FROM iobroker.datapoints WHERE name="'+DP+'"', function (result) { ....
Danke
-
@SBorg
Und noch eine Frage:
Ich wollte mir von der Froggit HP1000SE Pro die Single Sensor Edition holen.
Da sind die Sensoren DP300, DP40 und DP80 enthalten, die, wie ich gerade gesehen habe, nicht bei den unterstützten Sensoren dabei sind.
Ist es möglich diese im Skript hinzuzufügen? Und falls ja, welche Informationen werden benötigt?
Ich könnte da gerne unterstützen, sobald ich die WS habe.
Falls die Antwort nein ist, dann müsste ich nochmal drüber nachdenken, weil das Skript eins der Kaufkriterien für mich ist.
Ansonsten wäre das Skript für mich leider gar nicht nutzbar. -
@da_woody sagte in [Linux Shell-Skript] WLAN-Wetterstation:
bascht das so?
Jepp, sieht gut aus
[OT] btw: bin "etwas" hinterher mit YT schauen, aber warst du das mit der Klemsia bei Andy? Dann Glückwunsch
-
@negalein Du hast offensichtlich keinen "Default-Editor" angegeben. Eigentlich könnte ich auch 'nano wetterstation.conf' aufrufen, aber nicht jeder hat 'nano' und nicht jeder kennt sich notfalls mit 'vi' aus. Deswegen nehme ich den Editor den der User ausgewählt hat...
Hmm, da muss ich mir mal Gedanken machen, aber wahrscheinlich geht es dann nur so: kein Editor definiert --> nimm 'vi' (oder falls vorhanden 'nano')
Unicode will er offensichtlich bei dir auch nicht für die "Haken"......und "setrlimit" scheint auch ein Problem bei dir zu sein (hat aber nix mit dem Skript zu tun ) :https://forum.andronix.app/t/fix-sudo-setrlimit-rlimit-core-operation-not-permitted/53
-
@sborg sagte in [Linux Shell-Skript] WLAN-Wetterstation:
Du hast offensichtlich keinen "Default-Editor" angegeben
nachgeholt. Ist jetzt Nano und Wetterkonfig wird geöffnet.
...und "setrlimit" scheint auch ein Problem bei dir zu sein
auch nachgeholt.
Jetzt läuft alles durch.
Verbindung baut er nicht auf, da ich bewusst die IP nicht geändert habe. Sonst funkt mir der Test in die fertige rein. -
@viper4iob sagte in [Linux Shell-Skript] WLAN-Wetterstation:
Das Skript ist ja ein Shell-Skript und es gibt das Shell-Kommando "iobroker state set <id> <value> [<ack>]", um Datenpunkte im iobroker zu setzen.
Jetzt stellt sich die naheliegende Frage, ob es nicht Sinn machen würde das Shell-Kommando statt dem curl-Aufruf zu nutzen. Dann wäre man auch unabhängig von einem zusätzlichen Adapter.Hi erst mal
Ich sag mal Jein. Prinzipiell bräuchte man die API nicht unbedingt, aber wir sind mittlerweile bei >(möglichen) 100 Messwerte, ohne die die ich noch zusätzlich generiere. Die alle einzeln abzusetzen müllt die Kommunikation nicht nur zu, es könnte auch zeitlich mit dem folgenden Datenpaket eng werden. Per API werden die weitestgehend in einem Paket gesendet.@viper4iob sagte in [Linux Shell-Skript] WLAN-Wetterstation:
Gibt es eine Chance das Wetterstatistik Skript zu erweitern, so dass man auch die Daten aus MySQL nutzen könnte?
Pauschal ja, da es unter einer handvoll Abfragen sind (glaube 2 oder 3). Allerdings funktionieren ein paar Zusatzfunktionen des Shell-Skriptes ebenfalls per Influx.
Ich will keine Werbung für Influx machen, aber Influx ist dafür einfach die bessere Wahl, da es eine Timeline-Datenbank ist und dafür optimiert. Du hast halt den fortlaufenden Zeitstrahl und dann immer einen Messwert. MySQL bläht das dann extrem auf, ist aber die 1. Wahl wenn man mehrere Querreferenzierungen braucht wie zB. Filmsammlung "ich möchte alle Filme vor 2005 mit Clint Eastwood und John Wayne". Da versagt Influx völlig.
Soll trotzdem kein K.O.-Kriterium gegen MySQL sein, nur muss ich da auch die Zeit für finden, und das ist kein 5 Minuten Job.@viper4iob sagte in [Linux Shell-Skript] WLAN-Wetterstation:
Da sind die Sensoren DP300, DP40 und DP80 enthalten, die, wie ich gerade gesehen habe, nicht bei den unterstützten Sensoren dabei sind.
Ist es möglich diese im Skript hinzuzufügen? Und falls ja, welche Informationen werden benötigt?Ich sehe nichts spezielles was es verhindern würde. Allerdings sieht man es erst wenn auch Daten der Sensoren vorliegen. Bisher liefen aber alle und die drei sind nichts super spezielles. Ich brauche dann einfach nur mal einen Datenstring (
./wetterstation.sh --data
) mit den eingerichteten/aktivierten Sensoren, mehr nicht. Dann sind die auch zügig drin -
@negalein sagte in [Linux Shell-Skript] WLAN-Wetterstation:
Jetzt läuft alles durch.
Die "\u2713 - Haken" muss aber ich noch fixen, die kommen allerdings nicht vom Updater, sondern vom Shell-Skript...
-
@sborg sagte in [Linux Shell-Skript] WLAN-Wetterstation:
Die "\u2713 - Haken" muss aber ich noch fixen
Ahh, das soll der Hacken sein. Dachte mir schon was das bedeuten soll.
-
@negalein Habe ich bis dato noch nicht im Shell-Skript geändert. Nicht jeder Terminal-Emulator kommt aber mit dem Unicode-Steuerzeichen zu Recht, direkt als Haken funktioniert es dann aber
-
@sborg sagte in [Linux Shell-Skript] WLAN-Wetterstation:
aber warst du das mit der Klemsia bei Andy?
jup, das war meinereiner. das erste mal, daß ich was gewonnen habe.
wollte die klemmsis eh schon seit einiger zeit testen. jetzt kann ich ohne kosten... -
Vielen Dank für die ausführlichen Antworten.
Das wichtigste ist erst einmal, dass es überhaupt funktioniert.
Ich würde dann die entsprechenden Daten liefern, sobald ich sie habe, damit die Sensoren eingebaut werden können.
Das Thema curl Aufruf vs. Shell-Kommando habe ich verstanden, im Endeffekt wahrscheinlich ein Performance Thema und somit begründet.
Bzgl. der MySQL Anbindung, das wäre eine nice-to-have, weil ich es eh schon nutze, aber im Notfall muss ich eben noch eine InfluxDB aufsetzen, wäre jetzt auch nicht so dramatisch -
@da_woody sagte in [Linux Shell-Skript] WLAN-Wetterstation:
jup, das war meinereiner. das erste mal, daß ich was gewonnen habe.
Ich habe letzte Weihnachten auch das 1. mal gewonnen, dann aber gleich den Hauptpreis. Kpl. Arbeitskleidung von Nitras mit div. Arbeits-Hosen, Jacken, Mütze, Arbeitshandschuhe, Sicherheitsschuhe...
Ich mache aber nicht um des Gewinnenswillen mit, sondern nur wenn ich es auch wirklich brauchen kann. So freut sich bestimmt einer mehr bspw. über die Forstnerbohrer, als wenn sie bei mir im Regal verstauben...@viper4iob sagte in [Linux Shell-Skript] WLAN-Wetterstation:
Bzgl. der MySQL Anbindung, das wäre eine nice-to-have, weil ich es eh schon nutze, aber im Notfall muss ich eben noch eine InfluxDB aufsetzen, wäre jetzt auch nicht so dramatisch
Da würde ich aktuell vom Notfall ausgehen, denn eine Umsetzung sehe ich eher Mittel- denn Kurzfristig, da du auch aktuell der Einzige bist. Somit steht es auf der Prioliste nicht ganz oben
Bei den Sensoren sieht das dann anders aus, da ja ev. noch weitere Nutzer nachkommen (oder sie bereits halt nicht unterstützt nutzen) und das auch in 1-2 Stunden normalerweise umgesetzt ist. -
@sborg sagte in [Linux Shell-Skript] WLAN-Wetterstation:
@da_woody sagte in [Linux Shell-Skript] WLAN-Wetterstation:
jup, das war meinereiner. das erste mal, daß ich was gewonnen habe.
Ich habe letzte Weihnachten auch das 1. mal gewonnen, dann aber gleich den Hauptpreis. Kpl. Arbeitskleidung von Nitras mit div. Arbeits-Hosen, Jacken, Mütze, Arbeitshandschuhe, Sicherheitsschuhe...
Ich mache aber nicht um des Gewinnenswillen mit, sondern nur wenn ich es auch wirklich brauchen kann. So freut sich bestimmt einer mehr bspw. über die Forstnerbohrer, als wenn sie bei mir im Regal verstauben...arbeitskleidung ist mir schnuppe. wenn, dann mach ich nur bei dem mit, was ich brauchen kann. genau darum hab ich nur auf die klemmsis mich beworben. das andere war für mich nicht wichtig. so gesehen, sind wir ja eh am selben level. andere sollen das gewinnen, was sie brauchen zu glauben.
@viper4iob sagte in [Linux Shell-Skript] WLAN-Wetterstation:
Bzgl. der MySQL Anbindung, das wäre eine nice-to-have, weil ich es eh schon nutze, aber im Notfall muss ich eben noch eine InfluxDB aufsetzen, wäre jetzt auch nicht so dramatisch
Da würde ich aktuell vom Notfall ausgehen, denn eine Umsetzung sehe ich eher Mittel- denn Kurzfristig, da du auch aktuell der Einzige bist. Somit steht es auf der Prioliste nicht ganz oben
Bei den Sensoren sieht das dann anders aus, da ja ev. noch weitere Nutzer nachkommen (oder sie bereits halt nicht unterstützt nutzen) und das auch in 1-2 Stunden normalerweise umgesetzt ist.@viper4iob ich würde sagen, steig um auf influx. einfach, weils mit grafana einfacher ist und da auch mehr hilfe zu erwarten ist.
-
@sborg said in [Linux Shell-Skript] WLAN-Wetterstation:
@viper4iob sagte in [Linux Shell-Skript] WLAN-Wetterstation:
Bzgl. der MySQL Anbindung, das wäre eine nice-to-have, weil ich es eh schon nutze, aber im Notfall muss ich eben noch eine InfluxDB aufsetzen, wäre jetzt auch nicht so dramatisch
Da würde ich aktuell vom Notfall ausgehen, denn eine Umsetzung sehe ich eher Mittel- denn Kurzfristig, da du auch aktuell der Einzige bist. Somit steht es auf der Prioliste nicht ganz oben
@da_woody said in [Linux Shell-Skript] WLAN-Wetterstation:
@viper4iob ich würde sagen, steig um auf influx. einfach, weils mit grafana einfacher ist und da auch mehr hilfe zu erwarten ist.
Das mit Grafana habe ich auch schon mitbekommen, das ist mit MySQL etwas umständlich.
Und ja, der generelle Support in Verbindung mit influx ist einfach besser.
Ach ja: die InfluxDB läuft seit gestern und ich lasse auch schon testweise ein paar Datenpunkte aus iobroker rein schreiben