NEWS
js-controller 3.2 jetzt im Latest!
js-controller 3.2 jetzt im Latest!
-
Hallo ioBroker-Community,
mit etwas zeitlicher Verspätung, dafür aber um so besser, kommt heute der neue js-controller 3.2 (Releasename "Grace") ins Latest Repository (sollte im laufe des Abends bei allen auftauchen). Ein großer Dank geht an alle User die bereits in den Letzten Tagen diese Version im Beta test getestet und Probleme und Fehler zur Behebung gemeldet haben!
Node.js Versions-Anforderungen
Die unterstützten Node.js Versionen bleiben in diesem Update gleich: 10.x, 12.x und auch 14.x werden offiziell unterstützt. Aufgrund der übergreifenden Adapter-Kompatibilität bleibt die empfohlene Node.js Version für ioBroker aktuell weiterhin auf 12.x. Falls jemand wirklich mit Node.js 15.x experimentieren will, dann bitte AUSSCHLIESSLICH mit npm 6 !! (die npm Leute haben in npm 7 wieder Dinge geändert, die wir noch untersuchen)
Bitte beachtet weiterhin bei Node.js Updates die Anleitung im Forum unter https://forum.iobroker.net/post/266625Informationen zur Version
Neben einigen Features haben wir unter der Haube weiter aufgeräumt und sehr viel modernisiert und vereinheitlicht.
Auch daran den Wildwuchs in der Umsetzung einiger Adapter etwas einzugrenzen wurde weiter gearbeitet, was ggf. zu neuen Log-meldungen für bestimmte Fälle führt. Bitte unterstützt hier wieder und legt bei den relevanten Adaptern im GitHub Issues an, damit diese Dinge gefixt werden können.Besonders zu erwähnen ist die Grundlage für das neue Benachrichtigungssystem (kommt dann in einem Admin-Update) und die Reaktivierung von Let's Encrypt zur automatischen Zertifikatsaktualisierung.
Detailliertere Informationen zu allen Änderungen und Features findet Ihr weiter unten und im Changelog. Ich hoffe auch diesmal auf Eure tatkräftige Unterstützung, sodass der Latest-Release dann genau so reibungslos verläuft wie bei den letzten Versionen.In Summe sind in diese Version über 650 commits eingeflossen. Dafür bedenke mich diesmal besonders bei foxriver76, AlCalzone und natürlich Bluefox und auch ein paar weiteren Entwicklern für die aktive Mitarbeit an dieser Version!
Der js-controller 3.2 ist generell kompatibel mit allen bestehenden ioBroker-Systemen. Ein Update von der 2.0/2.1/2.2 ist problemlos möglich. Nur die Node.js Version muss jetzt mindestens 10.x sein, wie oben bereits ausgeführt. Wer überlegt die Node.js Version anzuheben bitte weiter unten im Abschnitt "Was ist zu testen" lesen

Es gibt aktuell keine inkompatiblem Adapter, aber einige Empfehlungen weiter unten.
Installation
VOR der Installation
Wie bei jedem Test dieser Art: Bitte macht ein Backup!
iobroker backupbzw kopieren desiobroker-dataVerzeichnisses reichen an sich aus. Bitte nicht das node_modules Verzeichnis einfach kopieren, da sonst symbolische Links kaputt gehen können, was zu größeren Problemen danach führt. Die alte Version des js-controller kann im Notfall einfach wieder pernpm install iobroker.js-controller@versioninstalliert werden und sollte alles wieder herstellen.Nötige Adapter-Aktualisierungen
Aktuell sind keine Inkompatibilitäten bekannt, damit allerdings Let's encrypt wieder funktioniert benötigt es einige Adapter in "Latest" Versionen von mindestens:
- ioBroker.lovelace 1.4.1 oder höher
- ioBroker.simple-api 2.5.2 oder höher
- ioBroker.socketio 3.1.3 oder höher
- ioBroker.telegram 1.7.0 oder höher
- ioBroker.web 3.2.2 oder höher
- ioBroker.admin 4.2.1 oder höher
Es werden aber, wie oben ausgeführt, einige Adapter ggf Warnungen ins Log schreiben. Falls das Problematisch ist ist aktuell die einzige Option das Loglevel der Instanz auf "Error" zu setzen.
Achtung: MASTER-Systeme Reihenfolgen beachten!
Bei einem Multi-Host-System, welches auf js-controller 2.2 oder 3.1 läuft ist es beim Update auf Version 3.2 empfohlen, zuerst das Master-System zu aktualisieren. Der Master muss dann wieder gestartet werden. Die Slaves werden danach aktualisiert!
Bei Updates von Master/Slave-Systemen mit js-controller 1.5 oder früher auf die 3.2 müssen zwingend zuerst die Slaves und der Master als letztes aktualisiert werden. Beim Slave Updat emuss der alte master aber noch laufen. Die Slaves bleiben nach dem Update offline und können sich nicht zum Master verbinden und werden erst wieder funktionieren wenn auch der Master auf die 3.2 aktualisiert wurde!
Windows
Auf Systemen, die mit dem neuen Windows Installer eingerichtet wurden weiss ich gerade nicht wie der aktuelle Prozess ist, da der Windows installer nicht ganz aktuell ist. Bitte hier berichten dann kann ich ergänzen.
Für alle "alten manuellen" Installationen gilt
- ioBroker muss gestoppt sein.
- Vor dem Update bitte prüfen das keine Prozesse mehr laufen
iobroker updateiobroker upgrade self- ioBroker starten
Linux
- ioBroker stoppen (
iobroker stop) - prüfen das keine Prozesse (Adapter, Backups) mehr laufen (
ps auxww|grep iound auchps auxww|grep backup). Es passiert manchmal das trotz dem Stoppen noch Zombies zurückbleiben iobroker update- Wie üblich wird das Update dann per
iobroker upgrade selfausgeführt. - ioBroker starten (
iobroker start)
Bei Fehlern:
Wenn bei der Installation Fehler wegen fehlender Zugriffsrechte auftreten, am besten den Installation-Fixer (iobroker fixwer schon einen js-controller 2.x oder höher hat, alternativ weiterhin manuell via curl -sL https://iobroker.net/fix.sh | bash -) nutzen und die Installation wiederholen.
Falls es auch danach noch Fehler gibt, bitte die Installation erneut mittelssudo -H -u iobroker npm install iobroker.js-controllerversuchen. Bitte berichtet solche Fälle hier im Thread.NACH der Installation
Nach der Installation den ioBroker wieder starten (z.B. mittels
iobroker start).Wenn alles klappt merkt Ihr ausser der höheren Versionsnummer in der Host-Ansicht im Admin keinen Unterschied. Alles funktioniert weiterhin wie vorher. Alle Adapterinstanzen starten und funktionieren. Wenn das so ist hat alles geklappt.
Falls im Log Warn-Meldungen auftauchen mit dem Hinweis diese an den Entwickler zu senden, dann bitte schauen welcher Adapter es ist und entsprechend dort Issues bitte anlegen!
Mit
iobroker helpwird eine Liste der möglichen Kommandozeilen-Kommandos angezeigt, die mit Version 2.0 um einige Befehle länger geworden ist. Es geht jetzt auch Kommandospezifisch Hilfe zu erhalten (iobroker upgrade --help)
Was hat sich geändert, was besonders ansehen/beachten?
Neben einiger weiterer Bugfixes gibt es folgende Änderungen und Fixes zu erwähnen:
- generell siehe Changelog, speziell auch für Features
- Let's Encrypt sollte wieder tun. Minimum Adapterversionen dazu siehe weiter oben!
- Einige Adapter werden Warnungen ausgeben wenn State-Werte gesetzt werden VOR dem Anlegen von Objekten. Bitte bei den Adapter-Repos melden
Speziell die Entwickler sollten bitte die genannten Deprecations anschauen und beachten
Wie bereits gesagt, viele Änderungen fanden hinter den Kulissen statt. Hier für Interessierte als Spoiler eine Zusammenfassung:
Generell ist zu testen, ob alles noch so funktioniert wie vorher auch. Das ist das wichtigste!
Wie Fehler melden?
Wer sich unsicher ist, ob ein Fehler vorliegt, sollte am besten hier im Thread das Problem beschreiben. So können wir alle versuchen, das Problem nachzuvollziehen und ggf. einzugrenzen.
Sobald ein Fehler auftritt der in einer Fehlermeldung oder einen Crash mit Fehlerdetails im Log oder auf Kommandozeile endet, dann dazu am besten direkt ein GitHub-Issue im js-controller Projekt öffnen und zusätzlich hier im Thread posten. Je detaillierter die Angaben im Issue sind (genaue Fehlermeldungen/Logs, Infos zur OS- und Node.js-Umgebung sowie genaue Schritte zur Reproduktion des Problems), umso schneller können wir Fehler einkreisen und beheben.
Wir wünschen allen viel Spaß beim Testen und vielen Dank für Eure Unterstützung!
Ingo
@apollon77
Läuft seit gestern Abend ohne Auffälligkeiten.
Gruß Marco -
Moin zusammen,
würde auch gerne aktualisieren aber bei mir zeigt er kein Update an, weder im Iobroker, noch, wenn ich über die Shell versuche zu aktualisieren.
System läuft bei mir auf der NAS im buanet Container, Master / Slave mit Raspberry Pi 4.
Aktuelle Version JS-controller auf beiden: 3.1.6Einfach ein wenig Geduld haben?
Danke und Grüße,
Volx -
Moin zusammen,
würde auch gerne aktualisieren aber bei mir zeigt er kein Update an, weder im Iobroker, noch, wenn ich über die Shell versuche zu aktualisieren.
System läuft bei mir auf der NAS im buanet Container, Master / Slave mit Raspberry Pi 4.
Aktuelle Version JS-controller auf beiden: 3.1.6Einfach ein wenig Geduld haben?
Danke und Grüße,
Volx@volx3eet hast du auch das repository auf latest ?
-
@volx3eet hast du auch das repository auf latest ?
@ilovegym said in js-controller 3.2 jetzt im Latest!:
@volx3eet hast du auch das repository auf latest ?
Beta müsste es sein.
-
@ilovegym said in js-controller 3.2 jetzt im Latest!:
@volx3eet hast du auch das repository auf latest ?
Beta müsste es sein.
-
@apollon77 verstehe ich jetzt nicht, die Meldung kommt doch, so wie der cron läuft, ich hab mir die nicht aus dem log zusammengesucht,
was ich damit meinte, es kamen 213 Meldungen fortlaufend am Stück -
@ilovegym said in js-controller 3.2 jetzt im Latest!:
@volx3eet hast du auch das repository auf latest ?
Beta müsste es sein.
@ofbeqnpolkkl6mby5e13 es gibt manchmal seltene caching Fälle. Versuch „iobroker update“ nochmal
-
@apollon77 ich hatte das log gestern live auf nem 2ten Bildschirm beobachtet, als die Meldungen im Millisekunden Takt kamen, hatte ich sie in nen Editor kopiert, um zu sehen, wie viele es ingesamt sind.
Nun habe ich das log von gestern durchgesehen, dort steht jedoch nur diese eine Meldung.
Ergo, passte etwas mit dem live log nicht.
sehr seltsam
-
@apollon77 ich hatte das log gestern live auf nem 2ten Bildschirm beobachtet, als die Meldungen im Millisekunden Takt kamen, hatte ich sie in nen Editor kopiert, um zu sehen, wie viele es ingesamt sind.
Nun habe ich das log von gestern durchgesehen, dort steht jedoch nur diese eine Meldung.
Ergo, passte etwas mit dem live log nicht.
sehr seltsam
-
@ofbeqnpolkkl6mby5e13 es gibt manchmal seltene caching Fälle. Versuch „iobroker update“ nochmal
@apollon77 said in js-controller 3.2 jetzt im Latest!:
@ofbeqnpolkkl6mby5e13 es gibt manchmal seltene caching Fälle. Versuch „iobroker update“ nochmal
War ich wirklich gemeint?
-
@apollon77 3.2.7 - nothing to report.
@ilovegym said in js-controller 3.2 jetzt im Latest!:
@apollon77 3.2.7 - nothing to report.
dito...läuft

-
@crunchip ahhh meinst das Admin es komisch angezeigt hat. Am Ende gewinnt immer das logfile auf Platte

@apollon77 said in js-controller 3.2 jetzt im Latest!:
@crunchip ahhh meinst das Admin es komisch angezeigt hat. Am Ende gewinnt immer das logfile auf Platte

Diesen Effekt hatte ich vor 1 bis 2 Tagen auch einmal. Da ich kurz vorher was gefiltert hatte dachte ich es käme vom Filter. Nach einem F5 war alles wieder gut.
-
@ilovegym said in js-controller 3.2 jetzt im Latest!:
@apollon77 3.2.7 - nothing to report.
dito...läuft

Ich habe lediglich drei Adapter mit Warnungen:
fullybrowser
hs100
proxmoxBei allen drei existiert ein Issue.
-
@crunchip ahhh meinst das Admin es komisch angezeigt hat. Am Ende gewinnt immer das logfile auf Platte

@apollon77 Bei mir war nach dem Update plötzlich der Terminaladapter auf aktiv geschaltet:
host.ioBroker 2021-01-17 10:51:18.887 info Restart adapter system.adapter.terminal.0 because enabled host.ioBroker 2021-01-17 10:51:18.886 error instance system.adapter.terminal.0 terminated with code 1 (JS_CONTROLLER_STOPPED) terminal.0 2021-01-17 10:51:18.712 error (23869) port 8081 already in use terminal.0 2021-01-17 10:51:18.392 info (23869) starting. Version 0.1.2 in /opt/iobroker/node_modules/iobroker.terminal, node: v12.20.1, js-controller: 3.2.7 host.ioBroker 2021-01-17 10:51:16.590 info instance system.adapter.terminal.0 started with pid 23869Nicht wichtig, da der nur mal vor langer Zeit für einen Sonderfall drauf war. Ich habe den jetzt deinstalliert.
-
@apollon77 3.2.7 - nothing to report.
@ilovegym said in js-controller 3.2 jetzt im Latest!:
@apollon77 3.2.7 - nothing to report.
bei mir genauso.

-
zwave2.0 Adapter läuft nicht mit dieser Version. Folgende Fehlermeldung wird ausgegeen wenn der Adapter gestartet wird. "Failed to load the configuration: config_1.loadDeviceClasses is not a function"
-
@apollon77 Heute um 17.00 Uhr hat der DWD Adapter folgendes gemeldet:
2021-01-17 17:00:31.794 - info: dwd.0 (15026) starting. Version 2.6.1 in /opt/iobroker/node_modules/iobroker.dwd, node: v12.18.3, js-controller: 3.2.7 2021-01-17 17:00:32.375 - info: dwd.0 (15026) Terminated (ADAPTER_REQUESTED_TERMINATION): Without reason 2021-01-17 17:00:32.974 - warn: dwd.0 (15026) get state Error: Connection is closed. 2021-01-17 17:00:32.979 - warn: dwd.0 (15026) get state Error: DB closed 2021-01-17 17:00:32.980 - warn: dwd.0 (15026) get state Error: DB closed 2021-01-17 17:00:32.981 - warn: dwd.0 (15026) get state Error: DB closed 2021-01-17 17:00:32.982 - warn: dwd.0 (15026) get state Error: DB closed 2021-01-17 17:00:32.986 - warn: dwd.0 (15026) get state Error: DB closed 2021-01-17 17:00:32.991 - warn: dwd.0 (15026) get state Error: DB closed 2021-01-17 17:00:32.993 - warn: dwd.0 (15026) get state Error: DB closed 2021-01-17 17:00:32.994 - warn: dwd.0 (15026) get state Error: DB closed 2021-01-17 17:00:32.997 - warn: dwd.0 (15026) get state Error: DB closed 2021-01-17 17:00:32.998 - warn: dwd.0 (15026) get state Error: DB closed 2021-01-17 17:00:33.001 - warn: dwd.0 (15026) get state Error: DB closed 2021-01-17 17:00:33.002 - warn: dwd.0 (15026) get state Error: DB closed 2021-01-17 17:00:33.004 - warn: dwd.0 (15026) get state Error: DB closed 2021-01-17 17:00:33.005 - warn: dwd.0 (15026) get state Error: DB closed 2021-01-17 17:00:33.007 - warn: dwd.0 (15026) get state Error: DB closed 2021-01-17 17:00:33.008 - warn: dwd.0 (15026) get state Error: DB closed 2021-01-17 17:00:33.009 - warn: dwd.0 (15026) get state Error: DB closed 2021-01-17 17:00:33.015 - warn: dwd.0 (15026) get state Error: DB closed 2021-01-17 17:00:33.016 - warn: dwd.0 (15026) get state Error: DB closed 2021-01-17 17:00:33.017 - warn: dwd.0 (15026) get state Error: DB closed 2021-01-17 17:00:33.018 - warn: dwd.0 (15026) get state Error: DB closed 2021-01-17 17:00:33.018 - warn: dwd.0 (15026) get state Error: DB closed 2021-01-17 17:00:33.019 - warn: dwd.0 (15026) get state Error: DB closed 2021-01-17 17:00:33.020 - warn: dwd.0 (15026) get state Error: DB closed 2021-01-17 17:00:33.027 - warn: dwd.0 (15026) get state Error: DB closed 2021-01-17 17:00:33.028 - warn: dwd.0 (15026) get state Error: DB closed 2021-01-17 17:00:33.028 - warn: dwd.0 (15026) get state Error: DB closed 2021-01-17 17:00:33.029 - warn: dwd.0 (15026) get state Error: DB closed 2021-01-17 17:00:33.029 - warn: dwd.0 (15026) get state Error: DB closed 2021-01-17 17:00:33.030 - warn: dwd.0 (15026) get state Error: DB closed 2021-01-17 17:00:33.031 - warn: dwd.0 (15026) get state Error: DB closed 2021-01-17 17:00:33.032 - warn: dwd.0 (15026) get state Error: DB closed 2021-01-17 17:00:33.032 - warn: dwd.0 (15026) get state Error: DB closed 2021-01-17 17:00:33.033 - warn: dwd.0 (15026) get state Error: DB closed 2021-01-17 17:00:33.039 - warn: dwd.0 (15026) get state Error: DB closed 2021-01-17 17:00:33.039 - warn: dwd.0 (15026) get state Error: DB closed 2021-01-17 17:00:33.040 - warn: dwd.0 (15026) get state Error: DB closed 2021-01-17 17:00:33.041 - warn: dwd.0 (15026) get state Error: DB closed 2021-01-17 17:00:33.042 - warn: dwd.0 (15026) get state Error: DB closed 2021-01-17 17:00:33.042 - warn: dwd.0 (15026) get state Error: DB closed 2021-01-17 17:00:33.047 - warn: dwd.0 (15026) get state Error: DB closed 2021-01-17 17:00:33.048 - warn: dwd.0 (15026) get state Error: DB closed 2021-01-17 17:00:33.049 - warn: dwd.0 (15026) get state Error: DB closed 2021-01-17 17:00:33.049 - warn: dwd.0 (15026) get state Error: DB closed 2021-01-17 17:00:33.050 - warn: dwd.0 (15026) get state Error: DB closed 2021-01-17 17:00:33.050 - warn: dwd.0 (15026) get state Error: DB closed 2021-01-17 17:00:33.056 - warn: dwd.0 (15026) get state Error: DB closed 2021-01-17 17:00:33.056 - warn: dwd.0 (15026) get state Error: DB closed 2021-01-17 17:00:33.057 - warn: dwd.0 (15026) get state Error: DB closed 2021-01-17 17:00:33.058 - warn: dwd.0 (15026) get state Error: DB closed 2021-01-17 17:00:33.162 - info: host.beebox(iobrokerMaster) instance system.adapter.dwd.0 terminated with code 11 (ADAPTER_REQUESTED_TERMINATION)Davor und danach war alles ruhig im Log.
-
zwave2.0 Adapter läuft nicht mit dieser Version. Folgende Fehlermeldung wird ausgegeen wenn der Adapter gestartet wird. "Failed to load the configuration: config_1.loadDeviceClasses is not a function"
