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. Skripten / Logik
  4. JavaScript
  5. Raspi GPIO wird gesetzt, wie Ursache herausfinden?

NEWS

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    21
    1
    844

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

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

Raspi GPIO wird gesetzt, wie Ursache herausfinden?

Geplant Angeheftet Gesperrt Verschoben JavaScript
65 Beiträge 4 Kommentatoren 5.8k Aufrufe 3 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.
  • L Laser

    @homoran bin ich gerade dabei! Manche Shellys fliegen raus. Werden aber als Weihnachtsbeleuchtung möglicherweise wieder gebraucht. Der gpio.22 soll aber bleiben.
    javascript.0.variables.kW-Hoy war ein Schreibfehler nach einer Änderung.

    HomoranH Offline
    HomoranH Offline
    Homoran
    Global Moderator Administrators
    schrieb am zuletzt editiert von
    #44

    @laser sagte in Raspi GPIO wird gesetzt, wie Ursache herausfinden?:

    Manche Shellys fliegen raus. Werden aber als Weihnachtsbeleuchtung möglicherweise wieder gebraucht.

    dann dürfen diese Skripte aber jetzt nicht laufen.
    Abgesehen von dem zugemüllten log, lähmt es dein System

    kein Support per PN! - Fragen im Forum stellen - es gibt fast nichts, was nicht auch für andere interessant ist.

    Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

    der Installationsfixer: curl -fsL https://iobroker.net/fix.sh | bash -

    1 Antwort Letzte Antwort
    0
    • L Laser

      @paul53 (6 und 25) Da soll ja auch geschaltet werden. Abends ein und Morgens wieder aus.
      Und wenn die Akkuspannung absinkt (im anderen Script).

      paul53P Offline
      paul53P Offline
      paul53
      schrieb am zuletzt editiert von paul53
      #45

      @laser sagte: Da soll ja auch geschaltet werden.

      ... aber nicht mit Zahlen 0 / 1, sondern mit false / true.

      Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
      Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

      L 1 Antwort Letzte Antwort
      0
      • paul53P paul53

        @laser sagte: Da soll ja auch geschaltet werden.

        ... aber nicht mit Zahlen 0 / 1, sondern mit false / true.

        L Offline
        L Offline
        Laser
        schrieb am zuletzt editiert von Laser
        #46

        @paul53 Das kapiere ich nicht. Wieso funktioniert das überhaupt mit 0 und 1? Ursprünglich hatte ich auch true und false drin. Bis zu einer Fehlermeldung (weiß ich aber nicht mehr genau). Da habe ich in 0 und 1 geändert. Habe das wieder in true/false abgeändert.

        paul53P 1 Antwort Letzte Antwort
        0
        • L Laser

          @paul53 Das kapiere ich nicht. Wieso funktioniert das überhaupt mit 0 und 1? Ursprünglich hatte ich auch true und false drin. Bis zu einer Fehlermeldung (weiß ich aber nicht mehr genau). Da habe ich in 0 und 1 geändert. Habe das wieder in true/false abgeändert.

          paul53P Offline
          paul53P Offline
          paul53
          schrieb am zuletzt editiert von paul53
          #47

          @laser sagte: Wieso funktioniert das überhaupt mit 0 und 1?

          Weil gewandelt wird. Es kommt aber eine Warnung zum falschen Typ.
          Vielleicht ist ja auch der Datenpunkttyp "boolean" falsch und er muss "number" sein?

          Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
          Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

          L 1 Antwort Letzte Antwort
          0
          • paul53P paul53

            @laser sagte: Wieso funktioniert das überhaupt mit 0 und 1?

            Weil gewandelt wird. Es kommt aber eine Warnung zum falschen Typ.
            Vielleicht ist ja auch der Datenpunkttyp "boolean" falsch und er muss "number" sein?

            L Offline
            L Offline
            Laser
            schrieb am zuletzt editiert von Laser
            #48

            @paul53 In den Objekten steht bei den GPIO "Logikwert". Irgendwas (weiß aber nicht mehr) funktionierte nur mit 0 und 1.
            Das gehe ich noch mal intensiv durch.

            paul53P T 2 Antworten Letzte Antwort
            0
            • L Laser

              @paul53 In den Objekten steht bei den GPIO "Logikwert". Irgendwas (weiß aber nicht mehr) funktionierte nur mit 0 und 1.
              Das gehe ich noch mal intensiv durch.

              paul53P Offline
              paul53P Offline
              paul53
              schrieb am zuletzt editiert von
              #49

              @laser sagte: Das gehe ich noch mal intensiv durch.

              Auszug aus der Datei main.js des Adapters "rpi2":

              function writeGpio(port, value) {
                  port = parseInt(port, 10);
                  if (!adapter.config.gpios[port] || !adapter.config.gpios[port].enabled) {
                      adapter.log.warn('Port ' + port + ' is not writable, because disabled.');
                      return;
                  } else if (adapter.config.gpios[port].input === 'in' || adapter.config.gpios[port].input === 'true' || adapter.config.gpios[port].input === true) {
                      return adapter.log.warn('Port ' + port + ' is configured as input and not writable');
                  }
              
                  if (value === 'true')  value = true;
                  if (value === 'false') value = false;
                  if (value === '0')     value = false;
                  value = !!value;
              

              Zahlen werden in Logikwerte gewandelt.

              Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
              Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

              1 Antwort Letzte Antwort
              1
              • L Laser

                @paul53 In den Objekten steht bei den GPIO "Logikwert". Irgendwas (weiß aber nicht mehr) funktionierte nur mit 0 und 1.
                Das gehe ich noch mal intensiv durch.

                T Offline
                T Offline
                ticaki
                schrieb am zuletzt editiert von ticaki
                #50

                @laser

                bin doch nicht weg:

                Em ja, das Skript macht nicht das was du willst.

                bitte achte beim Schreiben von Skripten auf das Einrücken, das verhindert schon mal ne Menge Fehler

                {
                  code hier
                  {
                    code hier
                    {
                      code hier
                    }
                    code hier
                  }
                  code hier
                }
                

                dann hast du in Deinem Skript sowas

                if (netzeinspeise <= (-0.01))
                if (netzeinspeise <= (-0.1))
                

                das erste If kannste auch weg lasen da jede Zahl kleiner -0.01 auch kleiner -0.1 ist.

                du wolltest wohl:

                if (netzeinspeise <= (-0.01)){
                } else if (netzeinspeise <= (-0.1)){
                } else if (netzeinspeise >= (0.1)){
                } usw.
                

                Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

                Spenden

                L 1 Antwort Letzte Antwort
                0
                • T ticaki

                  @laser

                  bin doch nicht weg:

                  Em ja, das Skript macht nicht das was du willst.

                  bitte achte beim Schreiben von Skripten auf das Einrücken, das verhindert schon mal ne Menge Fehler

                  {
                    code hier
                    {
                      code hier
                      {
                        code hier
                      }
                      code hier
                    }
                    code hier
                  }
                  

                  dann hast du in Deinem Skript sowas

                  if (netzeinspeise <= (-0.01))
                  if (netzeinspeise <= (-0.1))
                  

                  das erste If kannste auch weg lasen da jede Zahl kleiner -0.01 auch kleiner -0.1 ist.

                  du wolltest wohl:

                  if (netzeinspeise <= (-0.01)){
                  } else if (netzeinspeise <= (-0.1)){
                  } else if (netzeinspeise >= (0.1)){
                  } usw.
                  
                  L Offline
                  L Offline
                  Laser
                  schrieb am zuletzt editiert von Laser
                  #51

                  @ticaki Damit wollte ich etwas gestaffelt schalten. Wenn eine kleine Netzeinspeisung vorhanden ist, verändere den Wert (Eigenverbrauch) in 5 er Schritten. Wenn ein großer Wert vorliegt, ändere den Wert in großen Schritten. Z.B. wenn morgens der Toaster eingeschaltet wird, passe den Wert schneller an. Sonst in kleinen Schritten. Ist erst mal ein Versuch, ob ich so damit leben kann. Ist beim "Brot-Toasten" am Küchentisch entstanden. Besser geht immer.
                  Das Einrücken muß ich noch verbessern.

                  T 1 Antwort Letzte Antwort
                  0
                  • L Laser

                    @ticaki Damit wollte ich etwas gestaffelt schalten. Wenn eine kleine Netzeinspeisung vorhanden ist, verändere den Wert (Eigenverbrauch) in 5 er Schritten. Wenn ein großer Wert vorliegt, ändere den Wert in großen Schritten. Z.B. wenn morgens der Toaster eingeschaltet wird, passe den Wert schneller an. Sonst in kleinen Schritten. Ist erst mal ein Versuch, ob ich so damit leben kann. Ist beim "Brot-Toasten" am Küchentisch entstanden. Besser geht immer.
                    Das Einrücken muß ich noch verbessern.

                    T Offline
                    T Offline
                    ticaki
                    schrieb am zuletzt editiert von
                    #52

                    @laser
                    Ich zeige nur nicht optimalen Code auf. Das geht echt nicht darum irgendeine Bewertung vor zu nehmen. :)

                    Zum Code, eine gestaffelte Abfrage in der nur 1 von x Möglichkeiten ausgewählt werden soll, wird mit If () else if() else usw. aufgebaut, dann trifft immer nur 1 Möglichkeit zu.

                    Ich dachte du wolltest das erreichen.

                    Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

                    Spenden

                    L 1 Antwort Letzte Antwort
                    0
                    • T ticaki

                      @laser
                      Ich zeige nur nicht optimalen Code auf. Das geht echt nicht darum irgendeine Bewertung vor zu nehmen. :)

                      Zum Code, eine gestaffelte Abfrage in der nur 1 von x Möglichkeiten ausgewählt werden soll, wird mit If () else if() else usw. aufgebaut, dann trifft immer nur 1 Möglichkeit zu.

                      Ich dachte du wolltest das erreichen.

                      L Offline
                      L Offline
                      Laser
                      schrieb am zuletzt editiert von Laser
                      #53

                      @ticaki Werde ich anpassen. Das war wirklich mit der sehr heißen Nadel gestrickt. Das gefällt mir auch nicht.
                      @Homoran und die Logeinträge werden auch weniger. Bin da mal mit der Keule durch gegangen.

                      HomoranH 1 Antwort Letzte Antwort
                      0
                      • L Laser

                        @ticaki Werde ich anpassen. Das war wirklich mit der sehr heißen Nadel gestrickt. Das gefällt mir auch nicht.
                        @Homoran und die Logeinträge werden auch weniger. Bin da mal mit der Keule durch gegangen.

                        HomoranH Offline
                        HomoranH Offline
                        Homoran
                        Global Moderator Administrators
                        schrieb am zuletzt editiert von
                        #54

                        @laser sagte in Raspi GPIO wird gesetzt, wie Ursache herausfinden?:

                        die Logeinträge werden auch weniger. Bin da mal mit der Keule durch gegangen.

                        dann wird"s auch bald übersichtlicher im Log

                        kein Support per PN! - Fragen im Forum stellen - es gibt fast nichts, was nicht auch für andere interessant ist.

                        Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

                        der Installationsfixer: curl -fsL https://iobroker.net/fix.sh | bash -

                        L 1 Antwort Letzte Antwort
                        0
                        • HomoranH Homoran

                          @laser sagte in Raspi GPIO wird gesetzt, wie Ursache herausfinden?:

                          die Logeinträge werden auch weniger. Bin da mal mit der Keule durch gegangen.

                          dann wird"s auch bald übersichtlicher im Log

                          L Offline
                          L Offline
                          Laser
                          schrieb am zuletzt editiert von Laser
                          #55

                          @ticaki ist das so besser?

                          // über MQQT Datenpunkt beschreiben- alt, jetzt Adapter
                          let ZielwertM  = 80;
                          let ZielwertA = 180;
                          
                          schedule({hour: [19], minute:[10] },   function () {
                              setState('rpi2.0.gpio.22.state'/**/,true);  //  1 ist einschalten
                          });
                           // Abends einen anderen Sollwert zur Einspeisung setzen
                          schedule({hour: [19], minute:[15] },   function () {
                          //ZielwertA = getState('javascript.0.variables.SollwertHoy330Abend'/*SollwertHoy330Abend*/).val;
                          setState('opendtu.1.112184711203.power_control.limit_nonpersistent_absolute'/**/,ZielwertA);
                          });
                          
                           // Morgens einen anderen Sollwert zur Einspeisung setzen
                          schedule({hour: [02], minute:[15] },   function () { 
                          //ZielwertM = getState('javascript.0.variables.SollwertHoy300'/*SollwertHoy300*/).val;
                          setState('opendtu.1.112184711203.power_control.limit_nonpersistent_absolute'/**/, ZielwertM);
                          });
                          
                          schedule({hour: [09, 23 ], minute:[20] },   function () { 
                          setState('opendtu.1.112184711203.power_control.limit_nonpersistent_absolute'/**/,10); // vor dem Ausschalten runterfahren
                          });
                          
                          schedule({hour: [09,10 ], minute:[27] },   function () { 
                          setState('rpi2.0.gpio.22.state'/**/,false);  //  0 ist ausschalten
                          });
                          
                          // Anpassung der Einspeiseleistung (getaktet):
                          setInterval(Einspeisen,20000 );
                          function Einspeisen () {
                              let netzeinspeise = getState('javascript.0.variables.DP-kW-ges-Zaehler'/*DP-kW-ges-Zaehler*/).val;
                              let SWLeistung    = getState('opendtu.1.112184711203.power_control.limit_nonpersistent_absolute'/**/).val;
                              // console.log(" netzeinspeise: " +netzeinspeise);
                          
                              if (netzeinspeise <= (-0.01)){
                              SWLeistung = (SWLeistung -10);  // Wenn eingespeist wird, takte den SW Umrichter runter
                          
                              // Und schnell runterfahren bei großer Leistung ins Netz:
                              } else if (netzeinspeise <= (-0.1)) {
                              SWLeistung = (SWLeistung -100); // Wenn eingespeist wird, takte den SW Umrichter runter
                              // hochfahren:
                              } else if (netzeinspeise >= (0.01)){
                              SWLeistung = (SWLeistung +10);  // Wenn n. eingespeist wird, takte den SW Umrichter hoch
                          
                              // schnell hochfahren bei Verbraucher >100 Watt ein:
                              } else if (netzeinspeise >= (0.1)){
                              SWLeistung = (SWLeistung +100);  // Wenn n. eingespeist wird, takte den SW Umrichter hoch
                          
                              };   // Ende Else if
                          
                                  if (SWLeistung <=10)  {
                                  SWLeistung = 10;   // Begrenzer
                                  } else if (SWLeistung >=230) {
                                  SWLeistung = 230;  // Begrenzer    
                                  } else {SWLeistung = SWLeistung};
                                  console.log("Sollwert Lstg: " +SWLeistung);
                                  setState('opendtu.1.112184711203.power_control.limit_nonpersistent_absolute'/**/,SWLeistung);
                             
                          };  //Ende function Einspeisen
                          
                          T 1 Antwort Letzte Antwort
                          0
                          • L Laser

                            @ticaki ist das so besser?

                            // über MQQT Datenpunkt beschreiben- alt, jetzt Adapter
                            let ZielwertM  = 80;
                            let ZielwertA = 180;
                            
                            schedule({hour: [19], minute:[10] },   function () {
                                setState('rpi2.0.gpio.22.state'/**/,true);  //  1 ist einschalten
                            });
                             // Abends einen anderen Sollwert zur Einspeisung setzen
                            schedule({hour: [19], minute:[15] },   function () {
                            //ZielwertA = getState('javascript.0.variables.SollwertHoy330Abend'/*SollwertHoy330Abend*/).val;
                            setState('opendtu.1.112184711203.power_control.limit_nonpersistent_absolute'/**/,ZielwertA);
                            });
                            
                             // Morgens einen anderen Sollwert zur Einspeisung setzen
                            schedule({hour: [02], minute:[15] },   function () { 
                            //ZielwertM = getState('javascript.0.variables.SollwertHoy300'/*SollwertHoy300*/).val;
                            setState('opendtu.1.112184711203.power_control.limit_nonpersistent_absolute'/**/, ZielwertM);
                            });
                            
                            schedule({hour: [09, 23 ], minute:[20] },   function () { 
                            setState('opendtu.1.112184711203.power_control.limit_nonpersistent_absolute'/**/,10); // vor dem Ausschalten runterfahren
                            });
                            
                            schedule({hour: [09,10 ], minute:[27] },   function () { 
                            setState('rpi2.0.gpio.22.state'/**/,false);  //  0 ist ausschalten
                            });
                            
                            // Anpassung der Einspeiseleistung (getaktet):
                            setInterval(Einspeisen,20000 );
                            function Einspeisen () {
                                let netzeinspeise = getState('javascript.0.variables.DP-kW-ges-Zaehler'/*DP-kW-ges-Zaehler*/).val;
                                let SWLeistung    = getState('opendtu.1.112184711203.power_control.limit_nonpersistent_absolute'/**/).val;
                                // console.log(" netzeinspeise: " +netzeinspeise);
                            
                                if (netzeinspeise <= (-0.01)){
                                SWLeistung = (SWLeistung -10);  // Wenn eingespeist wird, takte den SW Umrichter runter
                            
                                // Und schnell runterfahren bei großer Leistung ins Netz:
                                } else if (netzeinspeise <= (-0.1)) {
                                SWLeistung = (SWLeistung -100); // Wenn eingespeist wird, takte den SW Umrichter runter
                                // hochfahren:
                                } else if (netzeinspeise >= (0.01)){
                                SWLeistung = (SWLeistung +10);  // Wenn n. eingespeist wird, takte den SW Umrichter hoch
                            
                                // schnell hochfahren bei Verbraucher >100 Watt ein:
                                } else if (netzeinspeise >= (0.1)){
                                SWLeistung = (SWLeistung +100);  // Wenn n. eingespeist wird, takte den SW Umrichter hoch
                            
                                };   // Ende Else if
                            
                                    if (SWLeistung <=10)  {
                                    SWLeistung = 10;   // Begrenzer
                                    } else if (SWLeistung >=230) {
                                    SWLeistung = 230;  // Begrenzer    
                                    } else {SWLeistung = SWLeistung};
                                    console.log("Sollwert Lstg: " +SWLeistung);
                                    setState('opendtu.1.112184711203.power_control.limit_nonpersistent_absolute'/**/,SWLeistung);
                               
                            };  //Ende function Einspeisen
                            
                            T Offline
                            T Offline
                            ticaki
                            schrieb am zuletzt editiert von ticaki
                            #56

                            @laser
                            :+1:

                            Eine kleine Optimierung am Ende: <= 10 braucht nur <10 wenns == 10 ist, ist es ja 10 :) auch für 230

                            und eine Formsache: ich würde das letzte else auch

                            } else {
                              SWLeistung = SWLeistung
                            }
                            

                            so schreiben ist beim lesen einfacher zu sehen das alles abgedeckt ist.

                            Wobei das letzte else ja keine Funktion hat, dann kannst du es auch erstmal leer lassen

                            Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

                            Spenden

                            L 1 Antwort Letzte Antwort
                            1
                            • T ticaki

                              @laser
                              :+1:

                              Eine kleine Optimierung am Ende: <= 10 braucht nur <10 wenns == 10 ist, ist es ja 10 :) auch für 230

                              und eine Formsache: ich würde das letzte else auch

                              } else {
                                SWLeistung = SWLeistung
                              }
                              

                              so schreiben ist beim lesen einfacher zu sehen das alles abgedeckt ist.

                              Wobei das letzte else ja keine Funktion hat, dann kannst du es auch erstmal leer lassen

                              L Offline
                              L Offline
                              Laser
                              schrieb am zuletzt editiert von Laser
                              #57

                              @ticaki Ist halt immer wieder was drangestrickt worden. Einfach mit copy/paste.
                              So gefällt mir das viel besser. Danke!

                              L 1 Antwort Letzte Antwort
                              0
                              • L Laser

                                @ticaki Ist halt immer wieder was drangestrickt worden. Einfach mit copy/paste.
                                So gefällt mir das viel besser. Danke!

                                L Offline
                                L Offline
                                Laser
                                schrieb am zuletzt editiert von Laser
                                #58

                                Das Script mußte ich noch etwas anpassen (die Staffelung der Grenzwerte). Funktioniert jetzt wie gewollt, nur übersichtlicher.
                                Auch das Log ist durch die Aufräumaktion übersichtlicher geworden. Aber 5:21 Uhr passiert immer noch etwas ungewolltes:
                                (Auch der VE-Error ist noch vorhanden. Genau um 5:21 Uhr. Da muß ich wohl noch etwas suchen.
                                Das Script SSH-Exec startet den VEdirect Adapter neu, wenn gestört. Da kommt aber nichts mit 5:21 Uhr vor
                                Das Modbus Gerät steht zu der Zeit.)

                                2023-07-24 05:21:52.759  - warn: javascript.0 (3320) You are assigning a number to the state "rpi2.0.gpio.22.state" which expects a boolean. Please fix your code to use a boolean or change the state type to number. This warning might become an error in future versions.
                                2023-07-24 05:21:52.761  - warn: javascript.0 (3320)     at Object.setState (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1730:20)
                                2023-07-24 05:21:52.761  - warn: javascript.0 (3320)     at Timeout._onTimeout (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1788:29)
                                2023-07-24 05:21:52.761  - warn: javascript.0 (3320)     at listOnTimeout (node:internal/timers:571:11)
                                2023-07-24 05:21:52.761  - warn: javascript.0 (3320)     at processTimers (node:internal/timers:512:7)
                                2023-07-24 05:21:52.770  - info: javascript.0 (3320) State value to set for "rpi2.0.gpio.22.state" has to be type "boolean" but received type "number" 
                                2023-07-24 05:21:53.074  - warn: modbus.0 (138498) Error: undefined
                                2023-07-24 05:21:53.076  - error: modbus.0 (138498) Request timed out.
                                2023-07-24 05:21:53.077  - error: modbus.0 (138498) Cannot write single register [1]: {"err":"timeout","timeout":5000}
                                2023-07-24 05:21:53.083  - info: javascript.0 (3320) script.js.Logik.SSH-Exec: VE Err: 1
                                2023-07-24 05:21:53.092  - info: javascript.0 (3320) script.js.Logik.SSH-Exec: VE Err: 1
                                2023-07-24 05:21:53.273  - warn: modbus.0 (138498) Poll error count: 2 code: "App Timeout"
                                2023-07-24 05:21:55.520  - info: javascript.0 (3320) script.js.Solar.Ges-Regler-_Lade-SWAnalog: Einspeise: 0.08
                                2023-07-24 05:21:55.521  - info: javascript.0 (3320) script.js.Solar.Ges-Regler-_Lade-SWAnalog:  Eigenverbr.Wert hoch
                                
                                

                                Allerdings schaltet der GPIO.22 nicht mehr ungewollt.
                                Was hat sich geändert? Das Script mit dem GPIO.22 habe ich kopiert (neuer Name) und angepasst (if Konstrukte durch else if ersetzt). Dem alten Script einen neuen Namen verpasst und nicht gestartet.

                                T 1 Antwort Letzte Antwort
                                0
                                • L Laser

                                  Das Script mußte ich noch etwas anpassen (die Staffelung der Grenzwerte). Funktioniert jetzt wie gewollt, nur übersichtlicher.
                                  Auch das Log ist durch die Aufräumaktion übersichtlicher geworden. Aber 5:21 Uhr passiert immer noch etwas ungewolltes:
                                  (Auch der VE-Error ist noch vorhanden. Genau um 5:21 Uhr. Da muß ich wohl noch etwas suchen.
                                  Das Script SSH-Exec startet den VEdirect Adapter neu, wenn gestört. Da kommt aber nichts mit 5:21 Uhr vor
                                  Das Modbus Gerät steht zu der Zeit.)

                                  2023-07-24 05:21:52.759  - warn: javascript.0 (3320) You are assigning a number to the state "rpi2.0.gpio.22.state" which expects a boolean. Please fix your code to use a boolean or change the state type to number. This warning might become an error in future versions.
                                  2023-07-24 05:21:52.761  - warn: javascript.0 (3320)     at Object.setState (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1730:20)
                                  2023-07-24 05:21:52.761  - warn: javascript.0 (3320)     at Timeout._onTimeout (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1788:29)
                                  2023-07-24 05:21:52.761  - warn: javascript.0 (3320)     at listOnTimeout (node:internal/timers:571:11)
                                  2023-07-24 05:21:52.761  - warn: javascript.0 (3320)     at processTimers (node:internal/timers:512:7)
                                  2023-07-24 05:21:52.770  - info: javascript.0 (3320) State value to set for "rpi2.0.gpio.22.state" has to be type "boolean" but received type "number" 
                                  2023-07-24 05:21:53.074  - warn: modbus.0 (138498) Error: undefined
                                  2023-07-24 05:21:53.076  - error: modbus.0 (138498) Request timed out.
                                  2023-07-24 05:21:53.077  - error: modbus.0 (138498) Cannot write single register [1]: {"err":"timeout","timeout":5000}
                                  2023-07-24 05:21:53.083  - info: javascript.0 (3320) script.js.Logik.SSH-Exec: VE Err: 1
                                  2023-07-24 05:21:53.092  - info: javascript.0 (3320) script.js.Logik.SSH-Exec: VE Err: 1
                                  2023-07-24 05:21:53.273  - warn: modbus.0 (138498) Poll error count: 2 code: "App Timeout"
                                  2023-07-24 05:21:55.520  - info: javascript.0 (3320) script.js.Solar.Ges-Regler-_Lade-SWAnalog: Einspeise: 0.08
                                  2023-07-24 05:21:55.521  - info: javascript.0 (3320) script.js.Solar.Ges-Regler-_Lade-SWAnalog:  Eigenverbr.Wert hoch
                                  
                                  

                                  Allerdings schaltet der GPIO.22 nicht mehr ungewollt.
                                  Was hat sich geändert? Das Script mit dem GPIO.22 habe ich kopiert (neuer Name) und angepasst (if Konstrukte durch else if ersetzt). Dem alten Script einen neuen Namen verpasst und nicht gestartet.

                                  T Offline
                                  T Offline
                                  ticaki
                                  schrieb am zuletzt editiert von
                                  #59

                                  @laser sagte in Raspi GPIO wird gesetzt, wie Ursache herausfinden?:

                                  Allerdings schaltet der GPIO.22 nicht mehr ungewollt.
                                  Was hat sich geändert?

                                  Na alle Skripte. Ich denke der Fehler kam durch das erste Skript das du hier gepostet hast.
                                  :)

                                  Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

                                  Spenden

                                  HomoranH 1 Antwort Letzte Antwort
                                  0
                                  • T ticaki

                                    @laser sagte in Raspi GPIO wird gesetzt, wie Ursache herausfinden?:

                                    Allerdings schaltet der GPIO.22 nicht mehr ungewollt.
                                    Was hat sich geändert?

                                    Na alle Skripte. Ich denke der Fehler kam durch das erste Skript das du hier gepostet hast.
                                    :)

                                    HomoranH Offline
                                    HomoranH Offline
                                    Homoran
                                    Global Moderator Administrators
                                    schrieb am zuletzt editiert von Homoran
                                    #60

                                    @ticaki sagte in Raspi GPIO wird gesetzt, wie Ursache herausfinden?:

                                    @laser sagte in Raspi GPIO wird gesetzt, wie Ursache herausfinden?:

                                    Allerdings schaltet der GPIO.22 nicht mehr ungewollt.
                                    Was hat sich geändert?

                                    Na alle Skripte. Ich denke der Fehler kam durch das erste Skript das du hier gepostet hast.
                                    :)

                                    (oder) durch die nichtverwendung von elseif,

                                    kein Support per PN! - Fragen im Forum stellen - es gibt fast nichts, was nicht auch für andere interessant ist.

                                    Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

                                    der Installationsfixer: curl -fsL https://iobroker.net/fix.sh | bash -

                                    L 1 Antwort Letzte Antwort
                                    0
                                    • HomoranH Homoran

                                      @ticaki sagte in Raspi GPIO wird gesetzt, wie Ursache herausfinden?:

                                      @laser sagte in Raspi GPIO wird gesetzt, wie Ursache herausfinden?:

                                      Allerdings schaltet der GPIO.22 nicht mehr ungewollt.
                                      Was hat sich geändert?

                                      Na alle Skripte. Ich denke der Fehler kam durch das erste Skript das du hier gepostet hast.
                                      :)

                                      (oder) durch die nichtverwendung von elseif,

                                      L Offline
                                      L Offline
                                      Laser
                                      schrieb am zuletzt editiert von
                                      #61

                                      @homoran evtl. war es wirklich das else if. Nur wie soll das bei einem gestoppten Script wirken?? Und den GPIO schalten?

                                      T 1 Antwort Letzte Antwort
                                      0
                                      • L Laser

                                        @homoran evtl. war es wirklich das else if. Nur wie soll das bei einem gestoppten Script wirken?? Und den GPIO schalten?

                                        T Offline
                                        T Offline
                                        ticaki
                                        schrieb am zuletzt editiert von ticaki
                                        #62

                                        @laser sagte in Raspi GPIO wird gesetzt, wie Ursache herausfinden?:

                                        @homoran evtl. war es wirklich das else if. Nur wie soll das bei einem gestoppten Script wirken?? Und den GPIO schalten?

                                        2023-07-24 05:21:52.759  - warn: javascript.0 (3320) You are assigning a number to the state "rpi2.0.gpio.22.state" which expects a boolean. Please fix your code to
                                        
                                        schedule({ hour: [19], minute: [10] }, function () {
                                          setState("rpi2.0.gpio.22.state" /**/, 1); //  1 ist einschalten
                                        });
                                        
                                        schedule({ hour: [09, 10], minute: [27] }, function () {
                                          setState("rpi2.0.gpio.22.state" /**/, 0); //  0 ist ausschalten
                                        });
                                        

                                        Wenn das alles im ersten Post gestanden hätte, wäre mir der Zusammenhang wohl direkt aufgefallen :)

                                        Wenn du nochmal sowas hast machs wie ich:

                                        schedule({ hour: [19], minute: [10] }, function () {
                                          log(1)
                                          setState("rpi2.0.gpio.22.state" /**/, 1); //  1 ist einschalten
                                        });
                                        
                                        schedule({ hour: [09, 10], minute: [27] }, function () {
                                          log(2)
                                          setState("rpi2.0.gpio.22.state" /**/, 0); //  0 ist ausschalten
                                        });
                                        

                                        und schau am nächsten Tag ins Log wer der Schuldige ist. :)

                                        Auch wenn ich keine Ahnung habe wieso das um die Uhrzeit schalten sollte, aber sind die einzigen falsch Zuweisungen in deinem Script...

                                        habs ausprobiert, wird richtig eingetragen:

                                        script.js.Test.Skript_122: {"type":"cron","pattern":{"hour":[19],"minute":[10]},"scriptName":"script.js.Test.Skript_122","id":"cron_1690278872308_51349"}
                                        script.js.Test.Skript_122: {"type":"cron","pattern":{"hour":[9,10],"minute":[27]},"scriptName":"script.js.Test.Skript_122","id":"cron_1690278872308_65468"}
                                        

                                        Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

                                        Spenden

                                        L 1 Antwort Letzte Antwort
                                        1
                                        • T ticaki

                                          @laser sagte in Raspi GPIO wird gesetzt, wie Ursache herausfinden?:

                                          @homoran evtl. war es wirklich das else if. Nur wie soll das bei einem gestoppten Script wirken?? Und den GPIO schalten?

                                          2023-07-24 05:21:52.759  - warn: javascript.0 (3320) You are assigning a number to the state "rpi2.0.gpio.22.state" which expects a boolean. Please fix your code to
                                          
                                          schedule({ hour: [19], minute: [10] }, function () {
                                            setState("rpi2.0.gpio.22.state" /**/, 1); //  1 ist einschalten
                                          });
                                          
                                          schedule({ hour: [09, 10], minute: [27] }, function () {
                                            setState("rpi2.0.gpio.22.state" /**/, 0); //  0 ist ausschalten
                                          });
                                          

                                          Wenn das alles im ersten Post gestanden hätte, wäre mir der Zusammenhang wohl direkt aufgefallen :)

                                          Wenn du nochmal sowas hast machs wie ich:

                                          schedule({ hour: [19], minute: [10] }, function () {
                                            log(1)
                                            setState("rpi2.0.gpio.22.state" /**/, 1); //  1 ist einschalten
                                          });
                                          
                                          schedule({ hour: [09, 10], minute: [27] }, function () {
                                            log(2)
                                            setState("rpi2.0.gpio.22.state" /**/, 0); //  0 ist ausschalten
                                          });
                                          

                                          und schau am nächsten Tag ins Log wer der Schuldige ist. :)

                                          Auch wenn ich keine Ahnung habe wieso das um die Uhrzeit schalten sollte, aber sind die einzigen falsch Zuweisungen in deinem Script...

                                          habs ausprobiert, wird richtig eingetragen:

                                          script.js.Test.Skript_122: {"type":"cron","pattern":{"hour":[19],"minute":[10]},"scriptName":"script.js.Test.Skript_122","id":"cron_1690278872308_51349"}
                                          script.js.Test.Skript_122: {"type":"cron","pattern":{"hour":[9,10],"minute":[27]},"scriptName":"script.js.Test.Skript_122","id":"cron_1690278872308_65468"}
                                          
                                          L Offline
                                          L Offline
                                          Laser
                                          schrieb am zuletzt editiert von Laser
                                          #63

                                          @ticaki Es ist der zweite Tag, wo es wie gewollt schaltet. Kein GPIO wird mehr fehlgeschaltet. Ich kann es nicht mehr nachvollziehen. Aber für mich sieht es immer noch so aus, als wenn Teile eines Scriptes weiterarbeiten, obwohl sie gelöscht wurden. Durch das umkopieren und umbenennen des Scriptes, und das Neustarten des Raspi tritt der Effekt nicht mehr auf.
                                          In einer früheren Variante des Scriptes habe ich den GPIO.22 um 23:00 Uhr aus und um 5:20 Uhr wieder eingeschaltet.

                                          paul53P 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

                                          405

                                          Online

                                          32.5k

                                          Benutzer

                                          81.6k

                                          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