NEWS
Test Adapter Admin 5.0.x: Alpha der neuen UI
-
Einen Guten Morgen - ich möchte nochmal kurz auf das Thema EBUSY Fehler unter ioB für Windows zu sprechen kommen.
Um ehrlich zu sein, weiß ich jetzt gar nicht mehr genau, ob das nun ein Admin 5.x oder ein js-controller 3.3.x Problem ist (war?) Jedenfalls habe ich bis dato nichts darüber gelesen, das es gefixt werden konnte.
Ich habe in diesem Zusammenhang festgestellt, das der EBUSY Fehler nicht auftritt, wenn man die Instanz vor dem Update händisch stoppt.
Alle Adapter Updates der letzten Zeit und das waren ja einige, wurden sauber ohne EBUSY Fehler bei gestoppter Instanz durchgeführt. Stoppt man die Instanz nicht, endet das Update mal mit EBUSY, mal wird es aber auch sauber durchgeführt.
Beim Admin Adapter sieht man als User ja ziemlich deutlich, das der Adapter angehalten wurde (drehender Kreis). Werden die anderen Adapter bei Updates nicht gestoppt, oder sieht man das nur nicht?
Wenn sie vom Update Prozess gestoppt werden, funktioniert dieses automatisch stoppen scheinbar nicht so sauber, als wenn ich die Instanz von Hand stoppe.
Für den Fall das dass EBUSY Problem nicht ohnehin schon gefixt wurde, wäre das ein möglicher Ansatz wo man suchen könnte?
-
@jb_sullivan sagte in Test Adapter Admin 5.0.x: Alpha der neuen UI:
Einen Guten Morgen - ich möchte nochmal kurz auf das Thema EBUSY Fehler unter ioB für Windows zu sprechen kommen.
Um ehrlich zu sein, weiß ich jetzt gar nicht mehr genau, ob das nun ein Admin 5.x oder ein js-controller 3.3.x Problem ist (war?) Jedenfalls habe ich bis dato nichts darüber gelesen, das es gefixt werden konnte.
Ich habe in diesem Zusammenhang festgestellt, das der EBUSY Fehler nicht auftritt, wenn man die Instanz vor dem Update händisch stoppt.
Alle Adapter Updates der letzten Zeit und das waren ja einige, wurden sauber ohne EBUSY Fehler bei gestoppter Instanz durchgeführt. Stoppt man die Instanz nicht, endet das Update mal mit EBUSY, mal wird es aber auch sauber durchgeführt.Das kann ich so bestätigen.
-
Ich denke es hat weder mit controller nocht mit einem Adapter zu tun sondern ich kann mir vorstellen (also Achtung immer noch annahmen!) das es an Windows liegt und ggf daran das wenn ein Prozess läuft ggf bestimmte Dateien gelockt sind und daher von einem npm Update nicht angefasst bzw darauf zugegriffen werden dürfen. Das könnte speziell bei "nativen Modulteilen" der Fall sein (wie Serialport oder so).
EBUSY heisst das auf eine File bzw Systemresource nicht zugegriffen werden kann (so verstehe/deute ich es im weiteren Sinne). Das würde auch erklären warum es dann tut wenn man den Adapter stoppt.
Aber da bin ich weit weg davon ein Windows-Experte zu sein weil unter Linux und macOS passiert das nicht.
Wenn diese Annahmen und Herleitung stimmt dann kann weder ioBroker noch irgendein Entwickler von uns etwas daran tun und es ist mit irgendeiner Node.js Version oder Windows Update passiert.
Man könnte also jetzt mal wild Node.js downgraden und schauen wie es sich mit anderen nodejs Versionen verhält ...
-
@apollon77 sagte in Test Adapter Admin 5.0.x: Alpha der neuen UI:
Ich denke es hat weder mit controller nocht mit einem Adapter zu tun
Ich denke schon, weil es ja vorher kein Problem damit gab.( Admin und/oder Controller)
Gerade auf meinen 2.Testsystem getestet:
Da haben alle Upgrades einwandfrei funktioniert
Admin: 4.2.1
JS controller: 3.2.16
Node.js: v12.20.0
NPM: 6.14.8 -
@sigi234 Das ist es ja aber: Wir machen nichts anders und der der Fehler meldet ist npm ... der läuft als separater Prozess. Ich wüsste nicht wie wir das beeinflussen könnten - auch weil es ja nicht immer vorkommt sondern scheinbar nur wenn native Bestandteile dabei sind ...
Ich kann daher nur vermuten.
Um es genauer zu WIssen muss sich jemand mit Windows System bzw Know How des Themas annehmen und mal alle optionen testen ... alte Admin versionen oder alter controller und/oder nodejs Versionen und mal versuchen rauszufinden was nun der Auslöser ist. Sonst steht "Vermutung gegen Vermutung"
Ich kann das leider nicht auch noch auf meine Kappe nehmen, hänge schon zuviele andere Dinge an meiner zu knappen Zeit. Also jegliche Unterstützung ist willkommen-
-
@apollon77 sagte in Test Adapter Admin 5.0.x: Alpha der neuen UI:
Um es genauer zu WIssen muss sich jemand mit Windows System bzw Know How des Themas annehmen
was für @Stabilostick
-
Wie ist das denn bei einem Adapter Update standard mäßig? Wird der Adapter vor der Update Routine gestoppt?
Wenn das bis jetzt nicht so sein sollte, wäre das doch etwas, was die ioB Entwickler einbauen könnten - oder? Der Admin wird ja auch vor dem Update gestoppt. Sofern es nicht sowieso passiert, wäre es unter Umständen vielleicht sogar für alle Adapter eine "sauberer" Lösung?
Wenn es unter LINUX nicht passiert, vielleicht könnte man im Rahmen des Update Prozess eine Prüfung auf das verwendete BS einbauen, sodaß nur bei Windows "Kunden" ein Zwangs Adapter Stop vor einem Update initiiert wird?!?!?
Sowohl Node.js als auch NPM waren vor dem Admin 5 /js-controller 3.3.x Update bei mir auf dem gleichen Stand wie sie es jetzt sind (bei mir NPM 6.14.11 // Node.js 14.16.0) - und unter den alten ioB Modulen hat es, so wie sigi auch schreibt, einwandfrei mit den Node/NPM Verionen funktioniert.
-
du vergisst eine nicht ganz so unwichtige komponente "Windows"
ergo du hast nie den gleichen zustand wie "immer"... mach ein reboot installiere dann ..
und du wirst merken der Fehler kommt nicht ... -
@jb_sullivan es gibt ein flag in der io-Package ob der adapter vor dem Update gestoppt werden soll. Könnte der adapter setzen. Aber vllt ne bessere Idee das bei Windows einfach explizit zu machen weil auf Linux ist es ja nicht nötig so kann die Ausfallzeiten des Adapters dort minimiert bleiben. Wäre ein js-Controller request und dann was für die 4.0 des Controllers im herbst
-
@apollon77
Mir ist aufgefallen, das ich unter Objekte eine Ordner "Script" habe, in dem genau ein Script meiner vielen Scripte ist.
Kannst du mir sagen was es mit dem Ordner auf sich hat oder für was der gedacht ist?
Und warum nur eines meiner Scripte darin ist?
-
@megawaldSchalte mal den Expertenmodus ein ... sind dann mehr EInträge da? Wenn ja sit das eine Skrpt vllt "das erste" was angelegt wurde bevor die Skript-Objekte einen "experts Only" Flag bekommen haben
-
@apollon77 @Megawaldi
Ist bei mir auch so, wenn der Expertemodus nicht aktiv sehe ich eine Teilmenge von meinen Skripten
Bei aktiviertem Expertenmode sehe ich alle.
@apollon77 Was ist denn das gewünschte Sollverhalten und wozu dienen diese Skripte-Objekte? Inhalte werden nicht angezeigt (mit aktivietem Expertenmodus)
-
@apollon77
Du hast natürlich recht. Im Expertenmodus sehe ich alle scripte. Wie kann man das denn beheben?
Was sich mir nicht erschließt ist, wozu dieser Script Ordner dient. Ich sehe ja alle scripte im Skripte reiter links? -
@feuersturm Wenn du den Datenpunkt des "Skript" bearbeitest und auf Objektdaten gehst, befindet sich das Javascript unter "source". Aber wozu kann ich auch nicht sagen...
-
Die Scripte werden ja auch in der Datenbank (objects.json) gespeichert, daher tauchen die auch unter Objekte auf (vermutlich wurde die bisher nur ausgeblendet).
-
@feuersturm damit kannst du ein Script ein oder auschalten... per script..
also mit einem Script ein anderes ausschalten oder neu starten
-
@megawaldi sagte in Test Adapter Admin 5.0.x: Alpha der neuen UI:
Im Expertenmodus sehe ich alle scripte. Wie kann man das denn beheben?
Speichere mal das betroffene script neu? ggf wird da der "expersonly" flag hinzugefügt.
-
@apollon77 Ich habe folgendes gemacht:
- Expertenmodus deaktiviert
- Ein Skript aussuchen, welche nicht unter script.js.Skripte sichtbar ist
- Dieses Skript inhaltlich ändern und speichern
In der Ansicht script.js.Skripte hat sich nichts geändert. Das geänderte Skript wird nicht sichbar. Soll der Bereich script.* überhaupt angezeigt werden bei nicht aktivem Expertenmodus?
-
@feuersturm Müsste man mal auf einer "jungfräulichen Installation" wo der JavasScript Adapter das erste mal installiert wird mal testen. Kann mir vorstellen das "alte Objekte" einfach so bleiben und nur neuere Skripte (keine Ahnung mehr mit welche JavaScript version (glaube 4.1?) das mit experts eingeführt wurde) korrekt angelegt werden. wäre dann ein issue für Javascript Adapter die objekte beim start zu prüfen und zu fixen
-
@apollon77 Ich hab mal einen frischen ioBroker mit js-controller 3.3.14 und Admin 5.1.9 aufgesetzt und dann JavaScript 5.1.3 installiert. Es sieht nachdem aus was du beschrieben hast:
Frische Installation
Zwei Skripte anglegt und mit deaktiviertem Expertenmodus
Expertenmodus aktiviert