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. ioBroker Allgemein
  4. Z-Wave Adapter Problem

NEWS

  • Monatsrückblick Januar/Februar 2026 ist online!
    BluefoxB
    Bluefox
    17
    1
    438

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    17
    1
    5.1k

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    13
    1
    1.4k

Z-Wave Adapter Problem

Geplant Angeheftet Gesperrt Verschoben ioBroker Allgemein
16 Beiträge 4 Kommentatoren 1.4k Aufrufe
  • Ä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.
  • Dominik_PunktD Offline
    Dominik_PunktD Offline
    Dominik_Punkt
    schrieb am zuletzt editiert von
    #2

    Hat echt keiner das gleiche Problem oder kann mir jemand helfen? Hier mal ein Auszug aus der LOG.

    zwave.0	2018-09-06 09:48:37.881	debug	setState for: nodeID=10: comClass=38: index=0: instance=1: value=20
    zwave.0	2018-09-06 09:48:37.881	debug	stateChange zwave.0.NODE10.SWITCH_MULTILEVEL.Level_1 set {"val":20,"ack":false,"ts":1536220117863,"q":0,"from":"system.adapter.javascript.1","lc":1536220017027}
    zwave.0	2018-09-06 09:48:37.879	debug	setState for: nodeID=12: comClass=38: index=0: instance=1: value=20
    zwave.0	2018-09-06 09:48:37.879	debug	stateChange zwave.0.NODE12.SWITCH_MULTILEVEL.Level_1 set {"val":20,"ack":false,"ts":1536220117862,"q":0,"from":"system.adapter.javascript.1","lc":1536220052682}
    zwave.0	2018-09-06 09:48:37.862	debug	setState for: nodeID=11: comClass=38: index=0: instance=1: value=20
    zwave.0	2018-09-06 09:48:37.862	debug	stateChange zwave.0.NODE11.SWITCH_MULTILEVEL.Level_1 set {"val":20,"ack":false,"ts":1536220117859,"q":0,"from":"system.adapter.javascript.1","lc":1536220027098}
    zwave.0	2018-09-06 09:48:37.852	debug	setState for: nodeID=9: comClass=38: index=0: instance=1: value=20
    zwave.0	2018-09-06 09:48:37.852	debug	stateChange zwave.0.NODE9.SWITCH_MULTILEVEL.Level_1 set {"val":20,"ack":false,"ts":1536220117827,"q":0,"from":"system.adapter.javascript.1","lc":1536219999755}
    zwave.0	2018-09-06 09:48:37.852	debug	setState for: nodeID=8: comClass=38: index=0: instance=1: value=20
    zwave.0	2018-09-06 09:48:37.852	debug	stateChange zwave.0.NODE8.SWITCH_MULTILEVEL.Level_1 set {"val":20,"ack":false,"ts":1536220117827,"q":0,"from":"system.adapter.javascript.1","lc":1536219986185}
    zwave.0	2018-09-06 09:48:37.852	debug	setState for: nodeID=10: comClass=38: index=0: instance=1: value=20
    zwave.0	2018-09-06 09:48:37.852	debug	stateChange zwave.0.NODE10.SWITCH_MULTILEVEL.Level_1 set {"val":20,"ack":false,"ts":1536220117827,"q":0,"from":"system.adapter.javascript.1","lc":1536220017027}
    zwave.0	2018-09-06 09:48:37.852	debug	setState for: nodeID=4: comClass=38: index=0: instance=1: value=20
    zwave.0	2018-09-06 09:48:37.851	debug	stateChange zwave.0.NODE4.SWITCH_MULTILEVEL.Level_1 set {"val":20,"ack":false,"ts":1536220117827,"q":0,"from":"system.adapter.javascript.1","lc":1536219985734}
    zwave.0	2018-09-06 09:48:37.851	debug	setState for: nodeID=11: comClass=38: index=0: instance=1: value=20
    zwave.0	2018-09-06 09:48:37.851	debug	stateChange zwave.0.NODE11.SWITCH_MULTILEVEL.Level_1 set {"val":20,"ack":false,"ts":1536220117827,"q":0,"from":"system.adapter.javascript.1","lc":1536220027098}
    zwave.0	2018-09-06 09:48:37.841	debug	value changed: 12 comClass: 38 value: {"value_id":"12-38-1-0","node_id":12,"class_id":38,"type":"byte","genre":"user","instance":1,"index":0,"label":"Level","units":"","help":"","read_only":false,"wri
    zwave.0	2018-09-06 09:48:37.831	debug	setState for: nodeID=7: comClass=38: index=0: instance=1: value=20
    zwave.0	2018-09-06 09:48:37.831	debug	stateChange zwave.0.NODE7.SWITCH_MULTILEVEL.Level_1 set {"val":20,"ack":false,"ts":1536220117823,"q":0,"from":"system.adapter.javascript.1","lc":1536219979263}
    zwave.0	2018-09-06 09:48:37.831	debug	setState for: nodeID=6: comClass=38: index=0: instance=1: value=20
    zwave.0	2018-09-06 09:48:37.830	debug	stateChange zwave.0.NODE6.SWITCH_MULTILEVEL.Level_1 set {"val":20,"ack":false,"ts":1536220117813,"q":0,"from":"system.adapter.javascript.1","lc":1536219983143}
    zwave.0	2018-09-06 09:48:37.830	debug	setState for: nodeID=12: comClass=38: index=0: instance=1: value=20
    zwave.0	2018-09-06 09:48:37.830	debug	stateChange zwave.0.NODE12.SWITCH_MULTILEVEL.Level_1 set {"val":20,"ack":false,"ts":1536220117812,"q":0,"from":"system.adapter.javascript.1","lc":1536220052682}
    zwave.0	2018-09-06 09:48:37.830	debug	setState for: nodeID=9: comClass=38: index=0: instance=1: value=20
    zwave.0	2018-09-06 09:48:37.830	debug	stateChange zwave.0.NODE9.SWITCH_MULTILEVEL.Level_1 set {"val":20,"ack":false,"ts":1536220117812,"q":0,"from":"system.adapter.javascript.1","lc":1536219999755}
    zwave.0	2018-09-06 09:48:37.830	debug	setState for: nodeID=11: comClass=38: index=0: instance=1: value=20
    zwave.0	2018-09-06 09:48:37.830	debug	stateChange zwave.0.NODE11.SWITCH_MULTILEVEL.Level_1 set {"val":20,"ack":false,"ts":1536220117812,"q":0,"from":"system.adapter.javascript.1","lc":1536220027098}
    zwave.0	2018-09-06 09:48:37.830	debug	setState for: nodeID=8: comClass=38: index=0: instance=1: value=20
    zwave.0	2018-09-06 09:48:37.830	debug	stateChange zwave.0.NODE8.SWITCH_MULTILEVEL.Level_1 set {"val":20,"ack":false,"ts":1536220117812,"q":0,"from":"system.adapter.javascript.1","lc":1536219986185}
    zwave.0	2018-09-06 09:48:37.830	debug	setState for: nodeID=10: comClass=38: index=0: instance=1: value=20
    zwave.0	2018-09-06 09:48:37.830	debug	stateChange zwave.0.NODE10.SWITCH_MULTILEVEL.Level_1 set {"val":20,"ack":false,"ts":1536220117812,"q":0,"from":"system.adapter.javascript.1","lc":1536220017027}
    zwave.0	2018-09-06 09:48:37.818	debug	setState for: nodeID=4: comClass=38: index=0: instance=1: value=20
    zwave.0	2018-09-06 09:48:37.817	debug	stateChange zwave.0.NODE4.SWITCH_MULTILEVEL.Level_1 set {"val":20,"ack":false,"ts":1536220117803,"q":0,"from":"system.adapter.javascript.1","lc":1536219985734}
    zwave.0	2018-09-06 09:48:37.809	debug	setState for: nodeID=12: comClass=38: index=0: instance=1: value=20
    
    1 Antwort Letzte Antwort
    0
    • AlCalzoneA Offline
      AlCalzoneA Offline
      AlCalzone
      Developer
      schrieb am zuletzt editiert von
      #3

      @Dominik_Punkt:

      Sollen mehrere Knoten gleichzeitig angesteuert werden, kommt es teilweise zu sehr hohen Verzögerungen. Wenn ich den Adapter auf debug stelle sieht es im Log so aus als ob alle paar ms neue "setstate" Befehle geschickt werden. `
      Eine gewisse Verzögerung ist zu erwarten, da ZWave intern die Befehle einreiht, aber die sollte sich im Rahmen einiger ms bewegen.

      Kannst du noch genau beschreiben (Skript-Code bzw. Blockly-Screenshot), wie du mehrere States gleichzeitig ansteuerst? Anhand des Logs gehe ich davon aus, dass die States tatsächlich mit Aktualisierungen zugebombt werden (aber von einer anderen Quelle aus ioBroker) und der Adapter bzw. der Treiber seine Probleme hat, hinterher zu kommen.

      Hier sind bspw zwei Schaltvorgänge für den selben Zustand und Wert innerhalb 40ms, die beide vom JS-Adapter ausgelöst wurden:

      [...] NODE10.SWITCH_MULTILEVEL.Level_1 set {"val":20,"ack":false,"ts":1536220117863,"q":0,"from":"system.adapter.javascript.1" [...]
      [...] NODE10.SWITCH_MULTILEVEL.Level_1 set {"val":20,"ack":false,"ts":1536220117827,"q":0,"from":"system.adapter.javascript.1" [...]
      

      Warum `sudo` böse ist: https://forum.iobroker.net/post/17109

      1 Antwort Letzte Antwort
      0
      • arteckA Offline
        arteckA Offline
        arteck
        Developer Most Active
        schrieb am zuletzt editiert von
        #4

        da loopt doch was nicht wie es soll

        zigbee hab ich, zwave auch, nuc's genauso und HA auch

        1 Antwort Letzte Antwort
        0
        • Dominik_PunktD Offline
          Dominik_PunktD Offline
          Dominik_Punkt
          schrieb am zuletzt editiert von
          #5

          Moin,

          also das es ist der Code vom Blocky. Es werden die einzelnen Rolladen mit einer Verzögerung angesteuert.

          on({id: 'vis.0.szene_2_sonne', val: true}, function (obj) {
            var value = obj.state.val;
            var oldValue = obj.oldState.val;
            setState("vis.0.szene_2_sonne"/*szene_2_sonne*/, false);
            // Rolladen
            setStateDelayed("zwave.0.NODE7.SWITCH_MULTILEVEL.Level_1"/*Rollade Wohnen Tür breit*/, 30, 100, false);
            setStateDelayed("zwave.0.NODE6.SWITCH_MULTILEVEL.Level_1"/*Rollade Wohnen Tür schmal*/, 30, 200, false);
            setStateDelayed("zwave.0.NODE5.SWITCH_MULTILEVEL.Level_1"/*Rollade Küche Tür*/, 99, 300, false);
            setStateDelayed("zwave.0.NODE4.SWITCH_MULTILEVEL.Level_1"/*Rollade Küche Fenster*/, 65, 400, false);
            setStateDelayed("zwave.0.NODE8.SWITCH_MULTILEVEL.Level_1"/*Rollade Büro Tür links*/, 30, 500, false);
            setStateDelayed("zwave.0.NODE9.SWITCH_MULTILEVEL.Level_1"/*Rollade Büro Tür rechts*/, 30, 600, false);
            setStateDelayed("zwave.0.NODE10.SWITCH_MULTILEVEL.Level_1"/*Rollade Schlafen Tür*/, 30, 700, false);
            setStateDelayed("zwave.0.NODE11.SWITCH_MULTILEVEL.Level_1"/*Rollade Schlafen Fenster*/, 65, 800, false);
            setStateDelayed("zwave.0.NODE12.SWITCH_MULTILEVEL.Level_1"/*Rollade Bad Fenster*/, 65, 900, false);
          });
          
          1 Antwort Letzte Antwort
          0
          • paul53P Offline
            paul53P Offline
            paul53
            schrieb am zuletzt editiert von
            #6

            @Dominik_Punkt:

            also das es ist der Code vom Blocky. `
            Das glaube ich nicht, dass es dieses Skript ist. Im Skript wird der Wert 30, im Log wird der Wert 20 gesetzt.

            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
            0
            • Dominik_PunktD Offline
              Dominik_PunktD Offline
              Dominik_Punkt
              schrieb am zuletzt editiert von
              #7

              Ja stimmt du hast recht. Die Skripte sind alle gleich halt mit unterschiedlichen Werten.

              1 Antwort Letzte Antwort
              0
              • AlCalzoneA Offline
                AlCalzoneA Offline
                AlCalzone
                Developer
                schrieb am zuletzt editiert von
                #8

                Dann müssen wir eine Ebene raus gehen. Irgendwas triggert dann wohl deine Szene mehrfach. Kannst du das nachvollziehen, indem du als ersten Befehl im Trigger mal dessen Quelle loggst?

                log(obj.from);
                
                

                Was potentiell kritisch sein könnte:

                on({id: 'vis.0.szene_2_sonne', val: true}, function (obj) {
                  // [...]
                  setState("vis.0.szene_2_sonne"/*szene_2_sonne*/, false);
                

                Wenn du in einem anderen Skript auf szene_2_sonne = false triggerst, hast du eine Endlosschleife.

                Warum `sudo` böse ist: https://forum.iobroker.net/post/17109

                1 Antwort Letzte Antwort
                0
                • Dominik_PunktD Offline
                  Dominik_PunktD Offline
                  Dominik_Punkt
                  schrieb am zuletzt editiert von
                  #9

                  Ich habe in der vis einen Button für die Rolladen Scene. Dieser setzt den Wert von einem Datenpunkt auf true. Dieser Datenpunkt triggert das Script wo er dann direkt wieder auf false zurück gesetzt wird. Ist dieser Ansatz falsch oder um die Ecke gedacht?

                  1 Antwort Letzte Antwort
                  0
                  • AlCalzoneA Offline
                    AlCalzoneA Offline
                    AlCalzone
                    Developer
                    schrieb am zuletzt editiert von
                    #10

                    Ansich ist das ok, aber… (siehe letzter Beitrag).

                    Warum `sudo` böse ist: https://forum.iobroker.net/post/17109

                    1 Antwort Letzte Antwort
                    0
                    • Dominik_PunktD Offline
                      Dominik_PunktD Offline
                      Dominik_Punkt
                      schrieb am zuletzt editiert von
                      #11

                      Ich habe den trigger jetzt auf "größer als letzte" gesetzt und werde jetzt mal beobachten ob er wieder in diese "Schleife" kommt. Danke ersteinmal, ich dachte echt es hat was mit dem Z-Wave Stick oder Adapter zu tun…

                      1 Antwort Letzte Antwort
                      0
                      • AlCalzoneA Offline
                        AlCalzoneA Offline
                        AlCalzone
                        Developer
                        schrieb am zuletzt editiert von
                        #12

                        Größer als / Kleiner als macht bei Logikwerten keinen Sinn. Was ist denn hiermit?
                        @AlCalzone:

                        Dann müssen wir eine Ebene raus gehen. Irgendwas triggert dann wohl deine Szene mehrfach. Kannst du das nachvollziehen, indem du als ersten Befehl im Trigger mal dessen Quelle loggst?

                        log(obj.from);
                        
                        ```` ` 

                        Warum `sudo` böse ist: https://forum.iobroker.net/post/17109

                        1 Antwort Letzte Antwort
                        0
                        • Dominik_PunktD Offline
                          Dominik_PunktD Offline
                          Dominik_Punkt
                          schrieb am zuletzt editiert von
                          #13

                          Wird der Logikwert nicht wie 0 und 1 behandelt also 1>0 ?

                          Ich weiß leider nicht wie ich mit dem log-Befehl vorgehen soll!? Wie bekomm ich das in ein blocky-script? Bitte einmal kurze Beschreibung

                          1 Antwort Letzte Antwort
                          0
                          • Dominik_PunktD Offline
                            Dominik_PunktD Offline
                            Dominik_Punkt
                            schrieb am zuletzt editiert von
                            #14

                            ` > CODE: ALLES AUSWÄHLEN

                            log(obj.from); `

                            wie bekomm ich das in ein blocky und was muss ich einstellen?

                            1 Antwort Letzte Antwort
                            0
                            • AlCalzoneA Offline
                              AlCalzoneA Offline
                              AlCalzone
                              Developer
                              schrieb am zuletzt editiert von
                              #15

                              @Dominik_Punkt:

                              wie bekomm ich das in ein blocky und was muss ich einstellen? `
                              Wie hier: obj.from ist "Ursprung", normalerweise wird auf dem Block "Objekt-ID" angezeigt.
                              1097_unbenannt.png

                              Warum `sudo` böse ist: https://forum.iobroker.net/post/17109

                              1 Antwort Letzte Antwort
                              0
                              • Dominik_PunktD Offline
                                Dominik_PunktD Offline
                                Dominik_Punkt
                                schrieb am zuletzt editiert von
                                #16

                                Ah ok und bei jedem Trigger kann ich dann 'Ursprung' im Log lesen. Ich teste das mal! Danke dir

                                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
                                FAQ Cloud / IOT
                                HowTo: Node.js-Update
                                HowTo: Backup/Restore
                                Downloads
                                BLOG

                                594

                                Online

                                32.7k

                                Benutzer

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