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. SQL-Adapter Entprellzeit

NEWS

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    15
    1
    540

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

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    1.9k

SQL-Adapter Entprellzeit

Geplant Angeheftet Gesperrt Verschoben ioBroker Allgemein
13 Beiträge 2 Kommentatoren 1.0k Aufrufe 1 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.
  • Dr. BakteriusD Online
    Dr. BakteriusD Online
    Dr. Bakterius
    Most Active
    schrieb am zuletzt editiert von
    #1

    Vielleicht verstehe ich das falsch, aber ich denke, dass innerhalb der Entprellzeit keine weiteren Werte aufgezeichnet werden sollten, oder? Ich habe eine Entprellzeit von 10000ms eingestellt und trotzdem in den Aufzeichnungen folgende Einträge:

    Wert	Bestätigt	Quelle	        Zeit	                          Geändert
    4.5	true	        maxcube.0	2018-10-10 08:10:03.984	
    20	true 	        maxcube.0	2018-10-10 07:55:03.268	
    20	true	        maxcube.0	2018-10-10 07:55:03.267	
    20	true	        maxcube.0	2018-10-10 07:55:01.004	
    17	true	        maxcube.0	2018-10-10 07:51:49.573
    
    

    Also innerhalb von 2 Sekunden drei (gleiche) Werte in der Datenbank. Was läuft da falsch?

    1 Antwort Letzte Antwort
    0
    • apollon77A Offline
      apollon77A Offline
      apollon77
      schrieb am zuletzt editiert von
      #2

      Da würde ich jetzt sagen: Debug Log bitte :-) Da sollte man sehen können was los ist.

      Beitrag hat geholfen? Votet rechts unten im Beitrag :-) https://paypal.me/Apollon77 / https://github.com/sponsors/Apollon77

      • Debug-Log für Instanz einschalten? Admin -> Instanzen -> Expertenmodus -> Instanz aufklappen - Loglevel ändern
      • Logfiles auf Platte /opt/iobroker/log/… nutzen, Admin schneidet Zeilen ab
      1 Antwort Letzte Antwort
      0
      • Dr. BakteriusD Online
        Dr. BakteriusD Online
        Dr. Bakterius
        Most Active
        schrieb am zuletzt editiert von
        #3

        Änderung des Wertes von 4.5 auf 12. Wieder drei Einträge in der Datenbank innerhalb von ca. 2 Sekunden. Hier das LOG dazu:

        2018-10-10 09:47:02.507 - debug: sql.0 new value received for maxcube.0.devices.thermostat_17b263.setpoint, new-value=12, ts=1539157622502, relog=false
        2018-10-10 09:47:02.708 - debug: sql.0 new value received for maxcube.0.devices.thermostat_17b263.setpoint, new-value=12, ts=1539157622703, relog=false
        2018-10-10 09:47:02.708 - debug: sql.0 value not changed maxcube.0.devices.thermostat_17b263.setpoint, last-value=12, new-value=12, ts=1539157622703
        2018-10-10 09:47:02.825 - debug: sql.0 new value received for maxcube.0.devices.thermostat_17b263.setpoint, new-value=4.5, ts=1539157622821, relog=false
        2018-10-10 09:47:02.826 - debug: sql.0 Min-Delta reached maxcube.0.devices.thermostat_17b263.setpoint, last-value=12, new-value=4.5, ts=1539157622821
        2018-10-10 09:47:02.826 - debug: sql.0 Datatype maxcube.0.devices.thermostat_17b263.setpoint: Currently: number, StorageType: false
        2018-10-10 09:47:02.827 - debug: sql.0 Type set in Def for maxcube.0.devices.thermostat_17b263.setpoint: false
        2018-10-10 09:47:02.827 - debug: sql.0 Type (from DB-Type) for maxcube.0.devices.thermostat_17b263.setpoint: 0
        2018-10-10 09:47:02.828 - debug: sql.0 SELECT id FROM `iobroker`.sources WHERE name='system.adapter.maxcube.0';
        2018-10-10 09:47:02.839 - debug: sql.0 INSERT INTO `iobroker`.ts_number (id, ts, val, ack, _from, q) VALUES(57, 1539157622703, 12, 1, 12, 0);
        2018-10-10 09:47:02.853 - debug: sql.0 DELETE FROM `iobroker`.ts_number WHERE id=57 AND ts < 1523346420853;
        2018-10-10 09:47:05.837 - debug: sql.0 new value received for maxcube.0.devices.thermostat_17b263.setpoint, new-value=12, ts=1539157625832, relog=false
        2018-10-10 09:47:05.838 - debug: sql.0 Min-Delta reached maxcube.0.devices.thermostat_17b263.setpoint, last-value=4.5, new-value=12, ts=1539157625832
        2018-10-10 09:47:12.508 - debug: sql.0 Datatype maxcube.0.devices.thermostat_17b263.setpoint: Currently: number, StorageType: Number
        2018-10-10 09:47:12.509 - debug: sql.0 INSERT INTO `iobroker`.ts_number (id, ts, val, ack, _from, q) VALUES(57, 1539157625832, 12, 1, 12, 0);
        2018-10-10 09:47:15.838 - debug: sql.0 Datatype maxcube.0.devices.thermostat_17b263.setpoint: Currently: number, StorageType: Number
        2018-10-10 09:47:15.840 - debug: sql.0 INSERT INTO `iobroker`.ts_number (id, ts, val, ack, _from, q) VALUES(57, 1539157625833, 12, 1, 12, 0);
        
        1 Antwort Letzte Antwort
        0
        • apollon77A Offline
          apollon77A Offline
          apollon77
          schrieb am zuletzt editiert von
          #4

          Zeig bitte mal die SQL-Konfig von dem Datenpunkt. Und bitte sagen welche sql-Version

          Beitrag hat geholfen? Votet rechts unten im Beitrag :-) https://paypal.me/Apollon77 / https://github.com/sponsors/Apollon77

          • Debug-Log für Instanz einschalten? Admin -> Instanzen -> Expertenmodus -> Instanz aufklappen - Loglevel ändern
          • Logfiles auf Platte /opt/iobroker/log/… nutzen, Admin schneidet Zeilen ab
          1 Antwort Letzte Antwort
          0
          • apollon77A Offline
            apollon77A Offline
            apollon77
            schrieb am zuletzt editiert von
            #5

            Ich glaube ich habe eine Vermuting zum Grund.

            Bitte installier mal Version vom Github, dann sql instanz neu starten. Falls nochmal passiert bitte nochmal Debug log.

            Konfig-Screenshot von oben bitte trotzdem schicken

            Beitrag hat geholfen? Votet rechts unten im Beitrag :-) https://paypal.me/Apollon77 / https://github.com/sponsors/Apollon77

            • Debug-Log für Instanz einschalten? Admin -> Instanzen -> Expertenmodus -> Instanz aufklappen - Loglevel ändern
            • Logfiles auf Platte /opt/iobroker/log/… nutzen, Admin schneidet Zeilen ab
            1 Antwort Letzte Antwort
            0
            • Dr. BakteriusD Online
              Dr. BakteriusD Online
              Dr. Bakterius
              Most Active
              schrieb am zuletzt editiert von
              #6

              Danke!

              Ich habe die Github-Version (1.9.3) installiert. Nach einem ersten Test passt es jetzt - nur ein Eintrag im LOG.

              2018-10-10 11:19:38.363 - debug: sql.0 new value received for maxcube.0.devices.thermostat_17b263.setpoint, new-value=12, ts=1539163178341, relog=false
              2018-10-10 11:19:38.492 - debug: sql.0 new value received for maxcube.0.devices.thermostat_17b263.setpoint, new-value=12, ts=1539163178486, relog=false
              2018-10-10 11:19:38.493 - debug: sql.0 value not changed maxcube.0.devices.thermostat_17b263.setpoint, last-value=12, new-value=12, ts=1539163178486
              2018-10-10 11:19:39.129 - debug: sql.0 new value received for maxcube.0.devices.thermostat_17b263.setpoint, new-value=4.5, ts=1539163179123, relog=false
              2018-10-10 11:19:39.130 - debug: sql.0 Min-Delta reached maxcube.0.devices.thermostat_17b263.setpoint, last-value=12, new-value=4.5, ts=1539163179123
              2018-10-10 11:19:39.133 - debug: sql.0 Datatype maxcube.0.devices.thermostat_17b263.setpoint: Currently: number, StorageType: false
              2018-10-10 11:19:39.140 - debug: sql.0 Type set in Def for maxcube.0.devices.thermostat_17b263.setpoint: false
              2018-10-10 11:19:39.141 - debug: sql.0 Type (from DB-Type) for maxcube.0.devices.thermostat_17b263.setpoint: 0
              2018-10-10 11:19:39.145 - debug: sql.0 INSERT INTO `iobroker`.ts_number (id, ts, val, ack, _from, q) VALUES(57, 1539163178486, 12, 1, 12, 0);
              2018-10-10 11:19:39.167 - debug: sql.0 DELETE FROM `iobroker`.ts_number WHERE id=57 AND ts < 1523351940166;
              2018-10-10 11:19:40.618 - debug: sql.0 new value received for maxcube.0.devices.thermostat_17b263.setpoint, new-value=12, ts=1539163180613, relog=false
              2018-10-10 11:19:40.619 - debug: sql.0 Min-Delta reached maxcube.0.devices.thermostat_17b263.setpoint, last-value=4.5, new-value=12, ts=1539163180613
              
              

              Hier noch die Konfig vom Datenpunkt:
              6909_sql.png

              1 Antwort Letzte Antwort
              0
              • apollon77A Offline
                apollon77A Offline
                apollon77
                schrieb am zuletzt editiert von
                #7

                Kannst es bitte noch bissl laufen lassen und heute Abend nochmal Checken/Feedback geben? Dann mache ich update fertig

                Beitrag hat geholfen? Votet rechts unten im Beitrag :-) https://paypal.me/Apollon77 / https://github.com/sponsors/Apollon77

                • Debug-Log für Instanz einschalten? Admin -> Instanzen -> Expertenmodus -> Instanz aufklappen - Loglevel ändern
                • Logfiles auf Platte /opt/iobroker/log/… nutzen, Admin schneidet Zeilen ab
                1 Antwort Letzte Antwort
                0
                • Dr. BakteriusD Online
                  Dr. BakteriusD Online
                  Dr. Bakterius
                  Most Active
                  schrieb am zuletzt editiert von
                  #8

                  So, einige Änderungen später muss ich die Erfolgsmeldung leider zurück nehmen. :(

                  Wert	Bestätigt	Quelle		Zeit			Geändert
                  23.5	true		maxcube.0	2018-10-10 18:00:02.884	
                  23.5	true		maxcube.0	2018-10-10 18:00:00.648	
                  19	true		maxcube.0	2018-10-10 14:20:03.392	
                  4.5	true		maxcube.0	2018-10-10 11:40:07.335	
                  4.5	true		maxcube.0	2018-10-10 11:40:00.608	
                  9	true		maxcube.0	2018-10-10 11:37:58.140	
                  4.5	true		maxcube.0	2018-10-10 11:32:57.843	
                  12	true		maxcube.0	2018-10-10 11:31:53.346	
                  12	true		maxcube.0	2018-10-10 11:31:50.200	
                  4.5	true		maxcube.0	2018-10-10 11:20:03.147	
                  4.5	true		maxcube.0	2018-10-10 11:20:00.589	
                  12	true		maxcube.0	2018-10-10 11:19:38.486
                  
                  

                  Ich kann den Adapter nicht ständig auf 'debug' laufen lassen, da ich doch so einige Datenpunkte aufzeichnen lasse und so tausende Zeilen an LOG auflaufen.

                  1 Antwort Letzte Antwort
                  0
                  • apollon77A Offline
                    apollon77A Offline
                    apollon77
                    schrieb am zuletzt editiert von
                    #9

                    Das ist mir klar aber ohne log ist das eher schwierig nachzuvollziehen und ich bin ehrlich: mir fehlt gerade komplett die Zeit es versuchen irgendwie manuell nachzustellen. Wenn es bei dir regelmäßig passiert ist das (für mich) gerade der einfachere Ansatz.

                    Jegliche Hilfe beschleunigt damit den fix. Sonst leg ein GitHub issue an und ich schaue es an wenn ich Zeit finde.

                    Jetzt sieht das log aber schon etwas nachvollziehbarer aus. Ich habe eine Vermutung, aber brauche debug log um die zu bestätigen.

                    Gesendet vom Handy …

                    Beitrag hat geholfen? Votet rechts unten im Beitrag :-) https://paypal.me/Apollon77 / https://github.com/sponsors/Apollon77

                    • Debug-Log für Instanz einschalten? Admin -> Instanzen -> Expertenmodus -> Instanz aufklappen - Loglevel ändern
                    • Logfiles auf Platte /opt/iobroker/log/… nutzen, Admin schneidet Zeilen ab
                    1 Antwort Letzte Antwort
                    0
                    • Dr. BakteriusD Online
                      Dr. BakteriusD Online
                      Dr. Bakterius
                      Most Active
                      schrieb am zuletzt editiert von
                      #10

                      Ich verstehe schon, du steckst ja wirklich viel Zeit und Arbeit in das Projekt. Deswegen versuche ich auch gerne zu helfen wo ich kann.

                      Ich habe es nun erneut versucht und "zum Glück" gleich beim ersten Mal einen Doppeleintrag geschafft. Hier dazu das LOG:

                      2018-10-10 19:45:08.263 - debug: sql.0 new value received for maxcube.0.devices.thermostat_17b263.setpoint, new-value=25, ts=1539193508255, relog=false
                      2018-10-10 19:45:08.453 - debug: sql.0 new value received for maxcube.0.devices.thermostat_17b263.setpoint, new-value=25, ts=1539193508448, relog=false
                      2018-10-10 19:45:08.454 - debug: sql.0 value not changed maxcube.0.devices.thermostat_17b263.setpoint, last-value=25, new-value=25, ts=1539193508448
                      2018-10-10 19:45:09.712 - debug: sql.0 new value received for maxcube.0.devices.thermostat_17b263.setpoint, new-value=23.5, ts=1539193509705, relog=false
                      2018-10-10 19:45:09.713 - debug: sql.0 Min-Delta reached maxcube.0.devices.thermostat_17b263.setpoint, last-value=25, new-value=23.5, ts=1539193509705
                      2018-10-10 19:45:09.714 - debug: sql.0 Datatype maxcube.0.devices.thermostat_17b263.setpoint: Currently: number, StorageType: false
                      2018-10-10 19:45:09.714 - debug: sql.0 Type set in Def for maxcube.0.devices.thermostat_17b263.setpoint: false
                      2018-10-10 19:45:09.715 - debug: sql.0 Type (from DB-Type) for maxcube.0.devices.thermostat_17b263.setpoint: 0
                      2018-10-10 19:45:09.715 - debug: sql.0 INSERT INTO `iobroker`.ts_number (id, ts, val, ack, _from, q) VALUES(57, 1539193508448, 25, 1, 12, 0);
                      2018-10-10 19:45:09.732 - debug: sql.0 DELETE FROM `iobroker`.ts_number WHERE id=57 AND ts < 1523382300731;
                      2018-10-10 19:45:11.200 - debug: sql.0 new value received for maxcube.0.devices.thermostat_17b263.setpoint, new-value=25, ts=1539193511195, relog=false
                      2018-10-10 19:45:11.201 - debug: sql.0 Min-Delta reached maxcube.0.devices.thermostat_17b263.setpoint, last-value=23.5, new-value=25, ts=1539193511195
                      2018-10-10 19:45:21.204 - debug: sql.0 Datatype maxcube.0.devices.thermostat_17b263.setpoint: Currently: number, StorageType: Number
                      2018-10-10 19:45:21.204 - debug: sql.0 INSERT INTO `iobroker`.ts_number (id, ts, val, ack, _from, q) VALUES(57, 1539193511195, 25, 1, 12, 0);
                      
                      

                      So wie ich das sehe, erfolgt ein Eintrag in die Datenbank sofort (19:45:09) und der zweite zehn Sekunden (Entprellzeit?) nachdem der Wert noch einmal ansteht (19:45:21). Eingetragen wird aber die Zeit, wo der Wert erneut gemeldet wurde - also rund 2 Sekunden nach dem ersten. Der zweite wird nicht verworfen, sondern nur verzögert geschrieben. Liege ich da richtig?

                      1 Antwort Letzte Antwort
                      0
                      • apollon77A Offline
                        apollon77A Offline
                        apollon77
                        schrieb am zuletzt editiert von
                        #11

                        Es ist wie ich vermutet habe. Hier "beisst" sich jetzt die Entprellzeit mit der Logik von "nur Änderungen loggen".

                        Bzw "beissen" ist falsch weil ja der "unstabile Wert" (die 23.5 in deinem Log-Fall) korrekterweise nicht geloggt wird. Also der Teil funktioniert.

                        Warum der stabile Wert so geloggt wird wie er es wird, liegt daran das der Adapter trotz "nur Änderungen loggen" versucht am Ende sinnvolle Werte zu haben die man für Visualisierung bzw. Berechnungen nutzen kann.

                        Wenn man wirklich nur Änderungen loggt und den Rest (also gleiche Werte) komplett verwirft,dann ist die formale Datenebene unvollständig weil ich nicht sehe wie lange der Wert wirklich stabil war bevor er sich geändert hat. Formal ist ja eine Treppenbewegung normal und viele Visualisierungen zeigen dann "schräge linien" an die nur die bekannten Datenpunkte verbinden, was ja aber ein falsches Bild abgibt.

                        Um hier als so korrekt zu arbeiten wir möglich merkt sich der Adapter intern auch den letzten "gleichen Wert" Event auch wenn er Ihn im ersten Schritt verworfen hat und wenn sich dann der Wert ändert wird dieses letzte verworfene Event verzögert geloggt, wie Du korrekt gesehen hast. So sieht man auf der Datenebene wie die "wirkliche Entwicklung" war.

                        In Zusammenhang mit der Entprellzeit passiert nun aktuell intern folgendes: neuer geänderter Wert kommt ist erstmal ok, triggert aber das Logging des letzten verworfenen Wertes. Das ist dann schon passiert auch wenn ggf die Änderung verworfen wird weil "instabil". :-(

                        Da muss ich drüber nachdenken bzw die Umstellung ist nicht ganz so easy und kann viele nebeneffekte haben, ich muss dich also leider vertrösten und hoffe der Effekt ist für dich erstmal erträglich?!

                        Würdest Du mir dazu beim Adapter ein GitHub issue bitte anlegen mit Referenz hierher? Wäre super …

                        Ingo

                        Beitrag hat geholfen? Votet rechts unten im Beitrag :-) https://paypal.me/Apollon77 / https://github.com/sponsors/Apollon77

                        • Debug-Log für Instanz einschalten? Admin -> Instanzen -> Expertenmodus -> Instanz aufklappen - Loglevel ändern
                        • Logfiles auf Platte /opt/iobroker/log/… nutzen, Admin schneidet Zeilen ab
                        1 Antwort Letzte Antwort
                        0
                        • Dr. BakteriusD Online
                          Dr. BakteriusD Online
                          Dr. Bakterius
                          Most Active
                          schrieb am zuletzt editiert von
                          #12

                          Danke für die Erklärung und fürs Dranbleiben.

                          Issue ist eingetragen (https://github.com/ioBroker/ioBroker.sql/issues/53).

                          1 Antwort Letzte Antwort
                          0
                          • apollon77A Offline
                            apollon77A Offline
                            apollon77
                            schrieb am zuletzt editiert von
                            #13

                            Für History habe ich das in der neuen "History 2.0.0" mal gefixt weil dort das gleiche Problem besteht. Wäre es möglich im vergleich sql/history mal anzusehen und zu sagen ob es in History 2.0.0 gefixt ist?

                            Details: https://forum.iobroker.net/topic/54197/test-adapter-history-2-0-0

                            Beitrag hat geholfen? Votet rechts unten im Beitrag :-) https://paypal.me/Apollon77 / https://github.com/sponsors/Apollon77

                            • Debug-Log für Instanz einschalten? Admin -> Instanzen -> Expertenmodus -> Instanz aufklappen - Loglevel ändern
                            • Logfiles auf Platte /opt/iobroker/log/… nutzen, Admin schneidet Zeilen ab
                            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

                            852

                            Online

                            32.6k

                            Benutzer

                            81.9k

                            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