Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Praktische Anwendungen (Showcase)
  4. [Linux Shell-Skript] WLAN-Wetterstation

NEWS

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    8.7k

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    13
    1
    2.2k

  • Neues Video "KI im Smart Home" - ioBroker plus n8n
    BluefoxB
    Bluefox
    16
    1
    3.1k

[Linux Shell-Skript] WLAN-Wetterstation

Geplant Angeheftet Gesperrt Verschoben Praktische Anwendungen (Showcase)
linuxshell-scriptwetterstationwlan-wetterstation
5.7k Beiträge 153 Kommentatoren 3.8m Aufrufe 135 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • Rene55R Rene55

    @SBorg zum Thema 'root': Bei mir sind alle Dateien 'pi:pi'. Ich hab seit gestern auf dem Raspberry das Log mitlaufen. Die Dateien, die das Script jetzt schreibt sind 'root:root'. Ist das so richtig (? @Thomas-Braun)?

    Thomas BraunT Online
    Thomas BraunT Online
    Thomas Braun
    Most Active
    schrieb am zuletzt editiert von
    #3304

    @rene55 sagte in [Linux Shell-Skript] WLAN-Wetterstation:

    Die Dateien, die das Script jetzt schreibt sind 'root:root'. Ist das so richtig

    Vermutlich nicht. Das skript darf nur Rechte im Kontext des users schreiben der es aufruft. Das kommt noch von dem falschen Besitzer des files.

    Linux-Werkzeugkasten:
    https://forum.iobroker.net/topic/42952/der-kleine-iobroker-linux-werkzeugkasten
    NodeJS Fixer Skript:
    https://forum.iobroker.net/topic/68035/iob-node-fix-skript
    iob_diag: curl -sLf -o diag.sh https://iobroker.net/diag.sh && bash diag.sh

    1 Antwort Letzte Antwort
    0
    • G Gezi70

      @thomas-braun Ich habe ein völlig neues Verzeichnis angelegt und neue Dateien eingefügt...

      Thomas BraunT Online
      Thomas BraunT Online
      Thomas Braun
      Most Active
      schrieb am zuletzt editiert von
      #3305

      @gezi70 sagte in [Linux Shell-Skript] WLAN-Wetterstation:

      Ich habe ein völlig neues Verzeichnis angelegt und neue Dateien eingefügt...

      Hört sich schwer nach Desktop-Betrieb an...

      Linux-Werkzeugkasten:
      https://forum.iobroker.net/topic/42952/der-kleine-iobroker-linux-werkzeugkasten
      NodeJS Fixer Skript:
      https://forum.iobroker.net/topic/68035/iob-node-fix-skript
      iob_diag: curl -sLf -o diag.sh https://iobroker.net/diag.sh && bash diag.sh

      G 1 Antwort Letzte Antwort
      0
      • Thomas BraunT Thomas Braun

        @gezi70 sagte in [Linux Shell-Skript] WLAN-Wetterstation:

        Ich habe ein völlig neues Verzeichnis angelegt und neue Dateien eingefügt...

        Hört sich schwer nach Desktop-Betrieb an...

        G Offline
        G Offline
        Gezi70
        schrieb am zuletzt editiert von
        #3306

        @thomas-braun

        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 BraunT 1 Antwort Letzte Antwort
        0
        • Rene55R Offline
          Rene55R Offline
          Rene55
          schrieb am zuletzt editiert von
          #3307

          @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.

          Host: Fujitsu Intel(R) Pentium(R) CPU G4560T, 32 GB RAM, Proxmox 8.x + lxc Ubuntu 22.04
          ioBroker (8 GB RAM) Node.js: 20.19.1, NPM: 10.8.2, js-Controller: 7.0.6, Admin: 7.6.3
          Wetterstation: Froggit WH3000SE V1.6.6

          Thomas BraunT 1 Antwort Letzte Antwort
          0
          • G Gezi70

            @thomas-braun

            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 BraunT Online
            Thomas BraunT Online
            Thomas Braun
            Most Active
            schrieb am zuletzt editiert von
            #3308

            @gezi70 sagte in [Linux Shell-Skript] WLAN-Wetterstation:

            /home/pi/wetterstation

            ls -la /home/pi/wetterstation
            

            Linux-Werkzeugkasten:
            https://forum.iobroker.net/topic/42952/der-kleine-iobroker-linux-werkzeugkasten
            NodeJS Fixer Skript:
            https://forum.iobroker.net/topic/68035/iob-node-fix-skript
            iob_diag: curl -sLf -o diag.sh https://iobroker.net/diag.sh && bash diag.sh

            G 2 Antworten Letzte Antwort
            0
            • Thomas BraunT Thomas Braun

              @gezi70 sagte in [Linux Shell-Skript] WLAN-Wetterstation:

              /home/pi/wetterstation

              ls -la /home/pi/wetterstation
              
              G Offline
              G Offline
              Gezi70
              schrieb am zuletzt editiert von
              #3309

              @thomas-braun läuft jetzt, danke

              1 Antwort Letzte Antwort
              0
              • Rene55R Rene55

                @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.

                Thomas BraunT Online
                Thomas BraunT Online
                Thomas Braun
                Most Active
                schrieb am zuletzt editiert von
                #3310

                @rene55

                Hast du den Service jetzt neugestartet?

                Da ich das skript nicht kenne weiß ich auch nicht was da genau läuft bzw. laufen sollte. Muss dir @SBorg wohl sagen.

                Linux-Werkzeugkasten:
                https://forum.iobroker.net/topic/42952/der-kleine-iobroker-linux-werkzeugkasten
                NodeJS Fixer Skript:
                https://forum.iobroker.net/topic/68035/iob-node-fix-skript
                iob_diag: curl -sLf -o diag.sh https://iobroker.net/diag.sh && bash diag.sh

                Rene55R 1 Antwort Letzte Antwort
                0
                • Thomas BraunT Thomas Braun

                  @rene55

                  Hast du den Service jetzt neugestartet?

                  Da ich das skript nicht kenne weiß ich auch nicht was da genau läuft bzw. laufen sollte. Muss dir @SBorg wohl sagen.

                  Rene55R Offline
                  Rene55R Offline
                  Rene55
                  schrieb am zuletzt editiert von Rene55
                  #3311

                  @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'.

                  Host: Fujitsu Intel(R) Pentium(R) CPU G4560T, 32 GB RAM, Proxmox 8.x + lxc Ubuntu 22.04
                  ioBroker (8 GB RAM) Node.js: 20.19.1, NPM: 10.8.2, js-Controller: 7.0.6, Admin: 7.6.3
                  Wetterstation: Froggit WH3000SE V1.6.6

                  SBorgS 1 Antwort Letzte Antwort
                  0
                  • Rene55R Rene55

                    @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'.

                    SBorgS Offline
                    SBorgS Offline
                    SBorg
                    Forum Testing Most Active
                    schrieb am zuletzt editiert von
                    #3312

                    @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 Zeilen

                    User=
                    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)

                    LG SBorg ( SBorg auf GitHub)
                    Projekte: Lebensmittelwarnung.de | WLAN-Wetterstation | PimpMyStation

                    Rene55R 1 Antwort Letzte Antwort
                    2
                    • SBorgS SBorg

                      @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 Zeilen

                      User=
                      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)

                      Rene55R Offline
                      Rene55R Offline
                      Rene55
                      schrieb am zuletzt editiert von
                      #3313

                      @sborg Super. Gefixt, Script läuft als 'pi' und schreibt auch Logs als 'pi'. :+1: Mercy

                      Host: Fujitsu Intel(R) Pentium(R) CPU G4560T, 32 GB RAM, Proxmox 8.x + lxc Ubuntu 22.04
                      ioBroker (8 GB RAM) Node.js: 20.19.1, NPM: 10.8.2, js-Controller: 7.0.6, Admin: 7.6.3
                      Wetterstation: Froggit WH3000SE V1.6.6

                      1 Antwort Letzte Antwort
                      0
                      • A Offline
                        A Offline
                        Andre105
                        schrieb am zuletzt editiert von
                        #3314

                        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.
                        
                        1 Antwort Letzte Antwort
                        0
                        • Thomas BraunT Online
                          Thomas BraunT Online
                          Thomas Braun
                          Most Active
                          schrieb am zuletzt editiert von
                          #3315

                          @andre105

                          nano
                          ist vermutlich der einfachste Editor auf Kommandozeile.

                          Linux-Werkzeugkasten:
                          https://forum.iobroker.net/topic/42952/der-kleine-iobroker-linux-werkzeugkasten
                          NodeJS Fixer Skript:
                          https://forum.iobroker.net/topic/68035/iob-node-fix-skript
                          iob_diag: curl -sLf -o diag.sh https://iobroker.net/diag.sh && bash diag.sh

                          A 1 Antwort Letzte Antwort
                          0
                          • Thomas BraunT Thomas Braun

                            @andre105

                            nano
                            ist vermutlich der einfachste Editor auf Kommandozeile.

                            A Offline
                            A Offline
                            Andre105
                            schrieb am zuletzt editiert von
                            #3316

                            @thomas-braun sagte in [Linux Shell-Skript] WLAN-Wetterstation:

                            @andre105

                            nano
                            ist vermutlich der einfachste Editor auf Kommandozeile.

                            Dann müsstw ich die Skriptdatei (wetterstation.js)auch in den Ordner verschieben?

                            Thomas BraunT 1 Antwort Letzte Antwort
                            0
                            • A Andre105

                              @thomas-braun sagte in [Linux Shell-Skript] WLAN-Wetterstation:

                              @andre105

                              nano
                              ist vermutlich der einfachste Editor auf Kommandozeile.

                              Dann müsstw ich die Skriptdatei (wetterstation.js)auch in den Ordner verschieben?

                              Thomas BraunT Online
                              Thomas BraunT Online
                              Thomas Braun
                              Most Active
                              schrieb am zuletzt editiert von
                              #3317

                              @andre105 Irgendein Verzeichnis im /home des users. Der Pfad dorthin wird ja in der service-Datei angegeben.

                              Linux-Werkzeugkasten:
                              https://forum.iobroker.net/topic/42952/der-kleine-iobroker-linux-werkzeugkasten
                              NodeJS Fixer Skript:
                              https://forum.iobroker.net/topic/68035/iob-node-fix-skript
                              iob_diag: curl -sLf -o diag.sh https://iobroker.net/diag.sh && bash diag.sh

                              1 Antwort Letzte Antwort
                              0
                              • A Offline
                                A Offline
                                Andre105
                                schrieb am zuletzt editiert von
                                #3318

                                Habe den Skript angelegt,gestartet und wieder gestoppt.
                                19220a34-0ec8-42b5-889e-39a1f16db07c-image.png

                                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?

                                SBorgS 1 Antwort Letzte Antwort
                                0
                                • A Andre105

                                  Habe den Skript angelegt,gestartet und wieder gestoppt.
                                  19220a34-0ec8-42b5-889e-39a1f16db07c-image.png

                                  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?

                                  SBorgS Offline
                                  SBorgS Offline
                                  SBorg
                                  Forum Testing Most Active
                                  schrieb am zuletzt editiert von
                                  #3319

                                  @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 -----------------------------------------------------------
                                  

                                  LG SBorg ( SBorg auf GitHub)
                                  Projekte: Lebensmittelwarnung.de | WLAN-Wetterstation | PimpMyStation

                                  A 1 Antwort Letzte Antwort
                                  0
                                  • SBorgS SBorg

                                    @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 -----------------------------------------------------------
                                    
                                    A Offline
                                    A Offline
                                    Andre105
                                    schrieb am zuletzt editiert von Andre105
                                    #3320

                                    @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$
                                    
                                    
                                    SBorgS 1 Antwort Letzte Antwort
                                    0
                                    • Thomas BraunT Thomas Braun

                                      @gezi70 sagte in [Linux Shell-Skript] WLAN-Wetterstation:

                                      /home/pi/wetterstation

                                      ls -la /home/pi/wetterstation
                                      
                                      G Offline
                                      G Offline
                                      Gezi70
                                      schrieb am zuletzt editiert von Gezi70
                                      #3321

                                      @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
                                      
                                      
                                      1 Antwort Letzte Antwort
                                      0
                                      • G Offline
                                        G Offline
                                        Gezi70
                                        schrieb am zuletzt editiert von
                                        #3322

                                        Jetzt geht es wieder. Ich hatte vergessen den TCP Port in der Config einzutragen. Dann kanns auch nicht gehen...

                                        1 Antwort Letzte Antwort
                                        0
                                        • SBorgS SBorg

                                          @tege0 Danke für die Rückmeldung eines neuen Modells :)

                                          1.)Wieso wird mir die gefühlt aber nicht die tatsächlich Außentemperatur angezeigt
                                          2.) Wie funktioniert nächster Regen? Was ist der Unterschied zu Regenvorschau?
                                          3.) wie Funktioniert das mit den Alias? Ist das nur ein aufruf auf Wind bzw. Opensensmap?
                                          4.) Wie erstelle ich den Verlauf für min/max Temp?

                                          zu 1): Liefert der Query Inspector von Grafana denn Daten dafür? Kontrolliere vorher mal die Panel-Einstellungen. Gerade "default/autogen" führt öfters zu keinen Daten.
                                          Bild 1.png


                                          zu 2): Regenvorschau sind die Daten für "heute" lt. WU; "nächster Regen" ist ein Skript welches das nächste Regenereignis bei WU innerhalb der nächsten 36h und die Wahrscheinlichkeit ausließt.

                                          /* Wunderground Regen
                                          Abfrage des Weatherunderground Adapters im Bereich Vorhersage,
                                          wann der nächste Regen erwartet wird.
                                          
                                          Findet in den forecastHourly-Datenpunkt den ersten Regen-Eintrag
                                          Ausgabe in Text ("kein Regen", "X Stunden (X% [Wahrscheinlichkeit])")
                                          
                                          http://forum.iobroker.net/viewtopic.php?f=21&t=3447#p31858
                                          
                                          
                                          01.08.2016 erstellt von Pix unter Nutzung des obigen Skriptes
                                          28.06.2017 Korrekturen
                                          12.07.2017 Fehler abfangen und Typ Variable auf String geändert
                                          06.03.2019 Code optimiert
                                                    berücksichtigt Niederschlag in der aktuellen Stunde (Stunde 0)
                                          11.06.2019 auf neue Datenpunkte angepasst für weatherground-Adapter (getestet V3.0.11)
                                          04.08.2019 geändert für Wunderground Adapter 3.1.1
                                          08.03.2021 Codeoptimierungen @SBorg
                                          
                                          */
                                          
                                          
                                          const vorstd = 36;                                       // Vorschau in Stunden (Weatherunderground bietet neuerdings bis 36h Vorschau), kann hier auch kleiner sein
                                          const idRegen = "0_userdata.0.VIS.Wetter.Regenvorschau"; // Ziel-Datenpunkt
                                          const wunder_inst = "weatherunderground.0.";             // Weatherground-Adapter Instanz
                                          const logging = false;
                                          
                                          createState(idRegen, "kein Regen", { name: "Regenvorschau", type: "string", role: "text" });
                                          
                                          
                                          function berechneZeit() {
                                             if (logging) log("Berechne Dauer in Stunden bis zum nächsten Regen");
                                             let data=0, pop=0;
                                             for (let i=0; i<vorstd; i++) {
                                                 data = getState(wunder_inst + "forecastHourly." + i + "h.precipitation").val;
                                                 if (data > 0) {   
                                                     pop = getState(wunder_inst + "forecastHourly." + i + "h.precipitationChance").val;
                                                     if (logging) log("Regeneintrag gefunden bei " + i + "h " + data + "mm");
                                                     if (i == 0) { // wenn jetzt Regen
                                                         if (logging) log("In dieser Stunde werden " + data + "mm Regen erwartet (Wahrscheinlichkeit " + pop + "%)");
                                                         setState(idRegen, "jetzt (" + pop + "%)", true);
                                                     } else {
                                                         if (logging) log("In " + i + " Stunden werden " + data + "mm Regen erwartet (Wahrscheinlichkeit " + pop + "%)");
                                                         if (i==1) { setState(idRegen, "1 Stunde (" + pop + "%)", true); } else { setState(idRegen, i + " Stunden (" + pop + "%)", true); }
                                                     }
                                                     i=vorstd-1; // beim ersten Auftreten der Regenwahrscheinlichkeit über 0 abbrechen
                                                 } 
                                                 if ((i == vorstd-1) && (pop == 0)) {
                                                     setState(idRegen, "Kein Regen erwartet (" + pop + "%)", true);
                                                     if (logging) log("Kein Regen erwartet (" + pop + "%)");
                                                 }
                                             }
                                          }
                                          
                                          // bei jeglicher Aktualisierung von Weatherunderground Berechnung starten
                                          
                                          on({
                                             id: /^weatherunderground\.[0-9]+\.forecast.*\.[0-9]+h\.precipitation$/,  // forecastHourly, forecastDaily, forecast
                                             change: "any"
                                          }, berechneZeit);
                                          
                                          // bei Skriptstart
                                          berechneZeit();
                                          
                                          


                                          zu 3): Grafana hat mit dem Versionswechsel auf 8 auch die Panels geändert. So ist es nicht mehr möglich direkt Booleans (true/false) für das benutzte Panel zu nutzen. Die Aliase setzen true/false einfach in 1/0 für die entsprechenden anzuzeigenden Wetterdienste um.


                                          zu 4): und wieder ein Skript ;)
                                          Nötig ist aber eigentlich nur die Außentemperatur...

                                          /*
                                          ########################################################################################################
                                          Berechnung von gleitendem Durchschnitt, Minimum und Maximum über einen Zeitraum von 1h und 24h
                                          Version 1.4.1
                                          ########################################################################################################
                                          
                                          
                                          Berechnet Min/Max, Durschschnitt und Median über die letzten 24h.
                                          Berechnet Min/Max, Durschschnitt über die letzte 1h.
                                          
                                          IDs aller benötigten Datenpunkte
                                          
                                          Als Array im Array mit folgendem Format:
                                           1.   original Datenpunktname
                                           2.   neuer Datenpunktname
                                                Beispiel:   javascript.0.Status.Temperatur.Außen
                                                            javascript.0.Status.Luftfeuchtigkeit.Außen
                                           3.   Beschreibung des Messwertes (zur Erzeugung neuer Datenpunkte)
                                                Beispiele:   Temperatur
                                                              Luftfeuchtigkeit
                                           4.   Einheit (zur Erzeugung neuer Datenpunkte)
                                                Beispiele:   °C, %H
                                          
                                          Ist beliebig erweiterbar und für beliebige Werte nutzbar.
                                          */
                                          
                                          "use strict";
                                          const idData = [['javascript.0.Wetterstation.Innentemperatur','javascript.0.Statistik.Temperatur.Wohnzimmer','Temperatur','°C'],
                                                         ['javascript.0.Wetterstation.Aussentemperatur','javascript.0.Statistik.Temperatur.Außen','Temperatur','°C'],
                                                         ['javascript.0.Wetterstation.Innenfeuchtigkeit','javascript.0.Statistik.Luftfeuchtigkeit.Wohnzimmer','Luftfeuchtigkeit','%H']];
                                          
                                          //Datenpunkt zur Speicherung aller internen Daten
                                          const dpData='javascript.0.Statistik.Statistic';
                                          
                                          // ########################################################################################################
                                          // Implementierung -- hier nichts mehr ändern
                                          // ########################################################################################################
                                          
                                          // globale Konstanten
                                          const tc = 5;         // Abtastrate in Minuten
                                          
                                          const statDataLength24 = Math.round((24 * 60) / tc); // Anzahl der Werte für 24h
                                          const statDataLength1 = Math.round(60 / tc); // Anzahl der Werte für stündlich
                                          
                                          // globale Variablen
                                          var listStatData;  //interne Speicherung aller Werte
                                          
                                          //Funktion zum einmaligem initialisieren aller Datenpunkte
                                          function initializeStatData() {
                                          
                                            // Datenpunkt zur Speicherung der internen Werte erzeugen
                                            createState(dpData, 0, false, {
                                               name: "StatisticData",
                                               read: true,
                                               write: true,
                                               desc: 'Statistische Daten',
                                               type: 'string',
                                               def: '',
                                               role: 'json'        
                                            });
                                            
                                            //internes Array initialisieren
                                             var needInit = false;
                                            try {
                                               listStatData = JSON.parse(getState(dpData).val);
                                            } catch (ex) {
                                               needInit = true;
                                            }
                                            if (needInit || !listStatData || (listStatData.length < idData.length)) {
                                               listStatData = new Array(idData.length); 
                                            }
                                            //logDebug('initializeStatData for', dpData, listStatData);
                                               
                                            for (var i = 0; i < idData.length; i++) {
                                                 if (!listStatData[i]) { listStatData[i] = {}; }
                                                 listStatData[i].value       = idData[i][1];
                                                 listStatData[i].max24h		= idData[i][1] + '.Max_24h';
                                                 listStatData[i].min24h		= idData[i][1] + '.Min_24h';
                                                 listStatData[i].mean24h		= idData[i][1] + '.Mean_24h';
                                                 listStatData[i].median24h	= idData[i][1] + '.Median_24h';
                                                 listStatData[i].max1h		= idData[i][1] + '.Max_1h';
                                                 listStatData[i].min1h		= idData[i][1] + '.Min_1h';
                                                 listStatData[i].mean1h		= idData[i][1] + '.Mean_1h';
                                          
                                               
                                             createState(listStatData[i].value, 0, false, {
                                                     name: idData[i][2],
                                                     read: true,
                                                     write: true,
                                                     desc: idData[i][2]+ ' Aktueller Wert',
                                               	    type: 'number',
                                                     def: 0,
                                                     unit: idData[i][3],
                                                     role: 'value'
                                             });
                                          
                                             createState(listStatData[i].max24h, 0, false, {
                                                     name: 'Maximum_24h',
                                                     read: true,
                                                     write: true,
                                                     desc: idData[i][2] + ' Maximum',
                                                     type: 'number',
                                                     def: 0,
                                                     unit: idData[i][3],
                                                     role: 'value'
                                                });
                                          
                                                createState(listStatData[i].min24h, 0, false, {
                                                     name: 'Minimum_24h',
                                                     read: true,
                                                     write: true,
                                                     desc: idData[i][2] + ' Minimum',
                                                     type: 'number',
                                                     def: 0,
                                                 unit: idData[i][3],
                                                     role: 'value'
                                                });
                                          
                                                createState(listStatData[i].mean24h, 0, false, {
                                                     name: 'Mittelwert_24h',
                                                     read: true,
                                                     write: true,
                                                     desc: idData[i][2] + ' Mittelwert',
                                                     type: 'number',
                                                     def: 0,
                                                     unit: idData[i][3],
                                                     role: 'value'
                                               });
                                          
                                               createState(listStatData[i].median24h, 0, false, {
                                                     name: 'Median_24h',
                                                     read: true,
                                                     write: true,
                                                     desc: idData[i][2] + ' Median',
                                                     type: 'number',
                                                     def: 0,
                                                     unit: idData[i][3],
                                                     role: 'value'
                                               });
                                          
                                               createState(listStatData[i].max1h, 0, false, {
                                                     name: 'Maximum_1h',
                                                     read: true,
                                                     write: true,
                                                     desc: idData[i][2] + ' Maximum',
                                                     type: 'number',
                                                     def: 0,
                                                     unit: idData[i][3],
                                                     role: 'value'
                                               });
                                          
                                               createState(listStatData[i].min1h, 0, false, {
                                                     name: 'Minimum_1h',
                                                     read: true,
                                                     write: true,
                                                     desc: idData[i][2] + ' Minimum',
                                                     type: 'number',
                                                     def: 0,
                                                     unit: idData[i][3],
                                                     role: 'value'
                                               });
                                          
                                               createState(listStatData[i].mean1h, 0, false, {
                                                     name: 'Mittelwert_1h',
                                                     read: true,
                                                     write: true,
                                                	    desc: idData[i][2] + ' Mittelwert',
                                                     type: 'number',
                                                     def: 0,
                                                 unit: idData[i][3],
                                                 role: 'value'
                                               });
                                               
                                               if (needInit || !listStatData[i].data || (listStatData[i].data.length != statDataLength24)) {
                                                     listStatData[i].data	= new Array(statDataLength24);
                                                   
                                                     // 1. Script start: Liste und String-Datenpunkt füllen
                                                     var x = getState(idData[i][0]).val;
                                                     for (var j = 0; j < statDataLength24; j++) {
                                                     listStatData[i].data[j] = x;
                                                  }
                                          
                                                   //logDebug(listStatData[i], i);
                                                     setStateDelayed(listStatData[i].value, x, false, 1000);
                                                     setStateDelayed(listStatData[i].min24h, x, false, 1000);
                                                     setStateDelayed(listStatData[i].max24h, x, false, 1000);
                                                     setStateDelayed(listStatData[i].mean24h, x, false, 1000);
                                                     setStateDelayed(listStatData[i].median24h, x, false, 1000);
                                                     setStateDelayed(listStatData[i].min1h, x, false, 1000);
                                                     setStateDelayed(listStatData[i].max1h, x, false, 1000);
                                                     setStateDelayed(listStatData[i].mean1h, x, false, 1000);
                                               }      
                                            }
                                            setState(dpData, JSON.stringify(listStatData));         
                                          }
                                          
                                          //Berechnung der Werte
                                          function calcStatData() {
                                            if (!listStatData || (idData.length != listStatData.length)) {
                                                 initializeStatData();
                                            }
                                             //logDebug('starting calcStatData');
                                               
                                            for (var i = 0; i < idData.length; i++) {
                                               
                                               listStatData[i].data.pop(); //Remove the last element of an array
                                               var x = parseFloat(getState(idData[i][0]).val);
                                               listStatData[i].data.unshift(x); //Add new items to the beginning of an array
                                               setState(listStatData[i].value, x);
                                               
                                               var min = x;
                                               var max = x;
                                               var sum = 0.0;
                                               for (var j = 0; j < statDataLength24; j++) {
                                                  var s = parseFloat(listStatData[i].data[j]);
                                                  if (s < min) min = s;
                                                  if (s > max) max = s;
                                                  sum += s;
                                                  if (j == (statDataLength1-1)) {
                                                     setState(listStatData[i].min1h, min);
                                                     setState(listStatData[i].max1h, max);
                                                     setState(listStatData[i].mean1h, round(sum / statDataLength1, 2));     
                                                  }
                                               }
                                               setState(listStatData[i].min24h, min);
                                               setState(listStatData[i].max24h, max);
                                               setState(listStatData[i].mean24h, round(sum / statDataLength24, 2));   
                                               setState(listStatData[i].median24h, getMedian(listStatData[i].data));
                                            }
                                            setState(dpData, JSON.stringify(listStatData));
                                          }    
                                          
                                          function getMedian(args) {
                                           if (!args.length) {return 0}
                                           var numbers = args.slice(0).sort((a,b) => a - b);
                                           var middle = Math.floor(numbers.length / 2);
                                           var isEven = numbers.length % 2 === 0;
                                           return isEven ? (numbers[middle] + numbers[middle - 1]) / 2 : numbers[middle];
                                          }
                                          
                                          /**
                                          * round a number
                                          * @param    value  to round
                                          * @param    exp    exponent to round
                                          * @returns         the round number
                                          */
                                          function round(value, exp) {
                                           if (typeof exp === 'undefined' || +exp === 0)
                                             return Math.round(value);
                                          
                                           value = +value;
                                           exp = +exp;
                                          
                                           if (isNaN(value) || !(typeof exp === 'number' && exp % 1 === 0))
                                             return NaN;
                                          
                                           // Shift
                                           var values = value.toString().split('e');
                                           value = Math.round(+(values[0] + 'e' + (values[1] ? (+values[1] + exp) : exp)));
                                          
                                           // Shift back
                                           values = value.toString().split('e');
                                           return +(values[0] + 'e' + (values[1] ? (+values[1] - exp) : -exp));
                                          }
                                          
                                          initializeStatData();
                                          
                                          schedule('*/' + tc + ' * * * *', function () {
                                            calcStatData();
                                          });
                                          


                                          Zudem wunder es mich das es nicht bei mir mit den Hintergrundbild funktioniert?

                                          Du musst dir ein Bild herunterladen und dann in das Grafana-Verzeichnis (/usr/share/grafana/public/img/) kopieren. Wenn du es wetter1.jpg nennst müsste es dann gleich angezeigt werden, andernfalls musst du im Boom-Theme-Panel dann den korrekten Namen angeben.

                                          Und ich habe das PimpMyStation gesehen, was hat das Aufsich?

                                          Baustelle und seit (shame on me) 1 Jahr nichts passiert. Ich finde einfach keine Zeit, und dass ist nicht eben mal in ein paar Tagen fertiggestellt. Das Projekt beinhaltet weitere Zusatzsensoren, die man sich einfach selbst aussuchen bzw. nachrüsten kann. Luftgüte, Blitzsensor, "echte" Sonnenstrahlung, Regensensor (nein, der Mengenmesser der Station taugt nichts für die Regenerkennung für bspw. eine Markise etc.), Himmelsthermometer ...

                                          T Offline
                                          T Offline
                                          tege0
                                          schrieb am zuletzt editiert von tege0
                                          #3323

                                          @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.

                                          49a505e8-2cf3-4879-84e9-5eba63217a50-image.png

                                          SBorgS 1 Antwort Letzte Antwort
                                          0
                                          Antworten
                                          • In einem neuen Thema antworten
                                          Anmelden zum Antworten
                                          • Älteste zuerst
                                          • Neuste zuerst
                                          • Meiste Stimmen


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          862

                                          Online

                                          32.4k

                                          Benutzer

                                          81.5k

                                          Themen

                                          1.3m

                                          Beiträge
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Anmelden

                                          • Du hast noch kein Konto? Registrieren

                                          • Anmelden oder registrieren, um zu suchen
                                          • Erster Beitrag
                                            Letzter Beitrag
                                          0
                                          • Home
                                          • Aktuell
                                          • Tags
                                          • Ungelesen 0
                                          • Kategorien
                                          • Unreplied
                                          • Beliebt
                                          • GitHub
                                          • Docu
                                          • Hilfe