Weiter zum Inhalt
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
Skins
  • Hell
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dunkel
  • 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. Subscription, Schedules, Timeouts explizit beenden?

NEWS

  • Neuer ioBroker-Blog online: Monatsrückblick März/April 2026
    BluefoxB
    Bluefox
    8
    1
    369

  • Verwendung von KI bitte immer deutlich kennzeichnen
    HomoranH
    Homoran
    10
    1
    326

  • Monatsrückblick Januar/Februar 2026 ist online!
    BluefoxB
    Bluefox
    18
    1
    945

Subscription, Schedules, Timeouts explizit beenden?

Geplant Angeheftet Gesperrt Verschoben Skripten / Logik
1 Beiträge 1 Kommentatoren 185 Aufrufe 1 Beobachtet
  • Ä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.
  • N Offline
    N Offline
    noox
    schrieb am zuletzt editiert von
    #1

    Ich bin eigentlich davon ausgegangen, dass mit dem Beenden eines Scripts auch State-Subscriptions, Schedules und auch JS-Timer (setTimeout()) automatisch beendet werden.

    Ich bin mir aber jetzt ziemlich sicher, dass das nicht immer der Fall ist. Ich verwende die Funktion "Mirror scripts to file path". D.h. ich editiere die Scripts mit Visual Studio Code in "/opt/iobroker/scripts" *)
    Vielleicht gibt es da einen Zusammenhang? Ich verwende außerdem TypeScript.

    Prinzipell hatte ich schon hin und wieder ein Verhalten, dass sich eventuell darauf zurückzuführen lässt. Aber die letzten 2 Tage hatte ich 3 Fälle:

    1. Hab an einem Script, das regelmäßig was durchführt, etwas geändert. Hab mir am nächsten Tag das Logfile angesehen, weil es am frühen Morgen nicht das tat, was ich wollte. Es gab regelmäßig einen Block von Log-Einträgen die gepasst haben. Und dann plötzlich einer, wo die Werte einfach nicht mit dem Code vereinbar waren. Also mehr Logging hinzugefügt. Am nächsten Tag habe ich dann Code-Blocks mit dem neuem Logging gefunden. Aber auch welche mit dem alten Logging - von vor der Änderung. Ich hab diesen Code von vor der Änderung aber nirgends im Code gefunden. JS-Adapter neu gestartet. Heutemorgen hat es gepasst.

    2. Ich hab ein (anderes) Script im Script-Editor offen. Ich beende es. Es wird angezeigt, dass es nicht läuft. Aber manche Log-Einträge laufen weiter. Das ganze ist mir aber erst aufgefallen, nachdem ich es ziemlich oft geändert und neu gestartet hatte.

    3. Ich hab dann einen onStop()-Handler eingefügt, um alle Subscriptions explizit zu entfernen. Ich hab das getestet. Es wurde aber vor dem Beenden noch ein 60 sec Timer mit setTimeout gestartet. Der wurde dann laut Logging auch knapp eine Minute nach dem Beenden des Scripts ausgeführt. Ich hab dann auch die setTimeout mit clearTimeout beendet. Jetzt scheint es zu passen.

    Heißt das, dass man immer mit dem onStop-Handler arbeiten sollte und alle State-Subscriptions und JS-Timer explizit beenden sollte?

    Im Dauerbetrieb fällt es vermutlicht nicht auf, weil ein Restart des JS-Adapter hilft und man ja normal nicht ständig die Scripte neu startet. Fall 1) war nämlich noch vor dem Restart von ioBroker um 5 Uhr.

    *) Tatsächlich habe ich die Scripts in einem eigenen Source-Folder und habe ein File-Watcher-Script, das geänderte Files von meinem Source-Folder nach "/opt/iobroker/scripts" kopiert. In meinem Source-Folder kann ich auch Imports verwenden um Code wiederzuverwenden. Der File-Watcher fügt dann die Imports direkt in das File ein, das er nach "/opt/iobroker/scripts" transferiert.
    Falls das Problem sonst keiner hat, liegts vielleicht daran. Das File-Watcher-Script läuft auch mit derselben Javascript-Instanz, wie die anderen Scripts.

    1 Antwort Letzte Antwort
    0

    Hey! Du scheinst an dieser Unterhaltung interessiert zu sein, hast aber noch kein Konto.

    Hast du es satt, bei jedem Besuch durch die gleichen Beiträge zu scrollen? Wenn du dich für ein Konto anmeldest, kommst du immer genau dorthin zurück, wo du zuvor warst, und kannst dich über neue Antworten benachrichtigen lassen (entweder per E-Mail oder Push-Benachrichtigung). Du kannst auch Lesezeichen speichern und Beiträge positiv bewerten, um anderen Community-Mitgliedern deine Wertschätzung zu zeigen.

    Mit deinem Input könnte dieser Beitrag noch besser werden 💗

    Registrieren Anmelden
    Antworten
    • In einem neuen Thema antworten
    Anmelden zum Antworten
    • Älteste zuerst
    • Neuste zuerst
    • Meiste Stimmen


    Support us

    ioBroker
    Community Adapters
    Donate

    574

    Online

    32.8k

    Benutzer

    82.8k

    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