You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Disclaimer: das Problem tritt vor allem auf langsamen Systemen auf, egal welche Controller version. Aktuell läuft alles auf v8.8.3.
Wenn ich eine Änderung an einem Skript während der Laufzeit der Codes eines Schedules speichere und damit das Script neustarte, läuft der Schedule des alten Scripts weiter und wird nicht gelöscht.
Erst ein echter Neustart der Instanz lässt dann nur noch einen Schedule laufen.
Ich habe in folgendem Log der Script-Instanz als "Namen" einen Zeitstempel mitgegeben, womit sie sich mit der Zeile "schedule start by instance xy" melden. Während der Laufzeit hab ich zwei mal Änderungen gespeichert. Man sieht, dass am Ende 3 Instanzen des Scripts parallel laufen, in den Schedule-listen der Instanz (getSchedules(true)) aber immer nur ein schedule auftaucht. Sie laufen also parallel und nicht in derselben schedule Liste.
Konkret geht es hier um das Skript "jsStrom_Ladesteuerung" welches die Parallelität erzeugt. Der Instanz"name" ist auch den Log einträgen beim auflisten der Schedules vorangestellt.
Schedule per onStop im Script zu handlen ist nicht benutzerfreundlich. Das Problem erzeugt vor allem auf leistungsschwachen Systemen zusätzliche Probleme, die nicht von jedem User erkannt werden. Die Problematik sollte Controller-seitig gelöst werden.
How?
Per onStop() und einen als Variable deklarierten schedule zu löschen wäre die manuelle Variante, die aber nicht benutzerfreundlich ist. Bei Erzeugung des schedules sollte dieser vom Controller registriert und bei Neustart des Scripts gelöscht werden.
The text was updated successfully, but these errors were encountered:
Das Problem erzeugt vor allem auf leistungsschwachen Systemen zusätzliche Probleme, die nicht von jedem User erkannt werden
Stimmt! Ich habe eine Woche lang nach dem Fehler gesucht und nicht gefunden.
Erst als ich mir testweise selber einen cronjob im Blockly gemacht habe welches jede Minute über Alexa ein Sprachkommando ausgibt welches NICHT gestoppt wurde nachdem ich das Skript gestoppt hatte habe ich es gemerkt.
Mein komplettes iobroker System ist Amok gelaufen.
No existing issues.
Description
Disclaimer: das Problem tritt vor allem auf langsamen Systemen auf, egal welche Controller version. Aktuell läuft alles auf v8.8.3.
Wenn ich eine Änderung an einem Skript während der Laufzeit der Codes eines Schedules speichere und damit das Script neustarte, läuft der Schedule des alten Scripts weiter und wird nicht gelöscht.
Erst ein echter Neustart der Instanz lässt dann nur noch einen Schedule laufen.
Ich habe in folgendem Log der Script-Instanz als "Namen" einen Zeitstempel mitgegeben, womit sie sich mit der Zeile "schedule start by instance xy" melden. Während der Laufzeit hab ich zwei mal Änderungen gespeichert. Man sieht, dass am Ende 3 Instanzen des Scripts parallel laufen, in den Schedule-listen der Instanz (getSchedules(true)) aber immer nur ein schedule auftaucht. Sie laufen also parallel und nicht in derselben schedule Liste.
Konkret geht es hier um das Skript "jsStrom_Ladesteuerung" welches die Parallelität erzeugt. Der Instanz"name" ist auch den Log einträgen beim auflisten der Schedules vorangestellt.
Why?
Schedule per onStop im Script zu handlen ist nicht benutzerfreundlich. Das Problem erzeugt vor allem auf leistungsschwachen Systemen zusätzliche Probleme, die nicht von jedem User erkannt werden. Die Problematik sollte Controller-seitig gelöst werden.
How?
Per onStop() und einen als Variable deklarierten schedule zu löschen wäre die manuelle Variante, die aber nicht benutzerfreundlich ist. Bei Erzeugung des schedules sollte dieser vom Controller registriert und bei Neustart des Scripts gelöscht werden.
The text was updated successfully, but these errors were encountered: