NEWS
ioBroker unter Windows installieren (ohne Installer)
-
@bahnuhr:
Um es nochmal zu konkretisieren: Ich denke, das Problem liegt beim js-controller, nicht direkt bei node. Auch ist es hier völlig Jacke wie Hose, ob man zuvor händisch oder mithilfe des Installer installiert hat!
Bei mir fing die Misere immer ganz genau in dem Moment an, in dem ich erstmals versucht habe, den js-controller auf v3.x zu aktualisieren. Alle anderen Adapter-Upgrades liefen problemlos durch und das System hat auch sämtliche Neustarts überstanden - bis eben der Versuch unternommen wurde, den js-controller zu aktualisieren...@AlCalzone:
Das Problem läßt sich, zumindest meiner Erfahrung nach, mit jedem System, völlig unabhängig von den installierten Adaptern und Instanzen, reproduzieren! Auch ist es völlig gleich, wie die Installation durchgeführt worden ist (händisch oder Installer).
Probier, wenn Du Zeit und Lust hast, einfach mal eine Installationsmethode aus, spiele ein bißchen mit den Adapter-Installationen herum, mach Neustarts etc. pp., ohne dabei aber den js-controller "anzufassen". Es wird mutmaßlich alles reibungslos klappen. Dann versuchst Du mal, den js-controller auf eine 3er Version hochzustufen (ich habe das immer über die Oberfläche des ioBroker statt über die Konsole gemacht) - und ab dann (in aller Regel spätestens nach dem ersten Neustart) hast Du den Salat!! -
Ich habe mal eine Frage zu der nodejs installation. Wenn man nodejs auf einem Windows System händisch installiert wird dieses ja im Programme Ordner abgelegt und ioB bekommt nicht mit, das auf Betriebssystem Ebene eine neuere Version liegt, als im ioB Ordner nodejs.
Wie installiert man nodejs denn korrekt, das auch ioBroker weiß, das es das neue nodejs ist?
-
@JB_Sullivan
In meiner Anleitung (Post 1) empfehle ich ja (inkl. Angabe des Links und Installationsanweisungen), das Node-Paket mithilfe eines Installer-Pakets (msi) zu installieren. Dadurch wird Node im System (Registry) eingetragen, sodaß eigentlich jedes Programm, das Node benötigt, dementsprechend auch "wissen" sollte, daß Node (in entsprechender Version) installiert ist.
Da der ioBroker problemlos läuft (solange man das "teuflische" js-controller Update nicht macht ), "weiß" er das wohl auch und greift dementsprechend auf die richtigen Dateien im richtigen Ordner zu! -
@P-A-L-A-D-I-N
Genau das ist nämlich bei mir nicht der Fall. nodejs ist als Version 12.18 installiert. ioB, behauptet aber immer noch, das es auf 10.17 unterwegs ist. -
@JB_Sullivan sagte in ioBroker unter Windows installieren (ohne Installer):
@P-A-L-A-D-I-N
Genau das ist nämlich bei mir nicht der Fall. nodejs ist als Version 12.18 installiert. ioB, behauptet aber immer noch, das es auf 10.17 unterwegs ist.Dies hatte bei mir geklappt.
1: Konsole: iobroker stop 2: Sicherung des Ordners: C:\Program Files\iobroker\SmartHome\nodejs auf dem Desktop 3: Download der benötigten Node.js Version unter https://nodejs.org als Archiv nicht als msi Datei 4: Entpacken des Downloads und kopieren den Gesamten Ordners über den vorhandenen C:\Program Files\iobroker\SmartHome\nodejs Ordner. 5: Kopiere aus der Sicherungskopie des Desktops die Datei nodevars.bat in den Ordner C:\Program Files\iobroker\SmartHome\nodejs 6: Konsole: iobroker start
-
@bahnuhr
Wenn ich es so mache wie von dir beschrieben, kommt bei Start des Windows Dienstes das hier -
@JB_Sullivan sagte in ioBroker unter Windows installieren (ohne Installer):
@bahnuhr
Wenn ich es so mache wie von dir beschrieben, kommt bei Start des Windows Dienstes das hierJetzt schau mal bitte ob es in deinem node_modules Ordner den Ordner node-windows gibt, und wenn nicht dann kopiere den rein. Danach sollte der Dienst wieder starten.
-
@stefande Alles Gut - SOrry war mein Fehler. Habe das Falsche Verzeichniss erwischt -node12.18 ist jetzt installiert.
-
Nur mal so zur Info, ich bastel zur Zeit an einem Workaround, wie man unter Windows ioBroker doch noch gefahrlos installiert bekommt - und zwar über den Installer.
Folgendes hat bislang funktioniert:
- Installation via Installer Version 2.1.0.b
- sofort Windows ioB Dienst stoppen
- nodesjs Verzeichnis gemäß dieser Anleitung "austauschen" auf aktuell 12.18
1: Konsole: iobroker stop 2: Sicherung des Ordners: C:\Program Files\iobroker\SmartHome\nodejs auf dem Desktop 3: Download der benötigten Node.js Version unter https://nodejs.org als Archiv nicht als msi Datei 4: Entpacken des Downloads und kopieren den Gesamten Ordners über den vorhandenen C:\Program Files\iobroker\SmartHome\nodejs Ordner. 5: Kopiere aus der Sicherungskopie des Desktops die Datei nodevars.bat in den Ordner C:\Program Files\iobroker\SmartHome\nodejs 6: Konsole: iobroker start
- Windows ioB Dienst starten
- ioB Admin aufrufen, nodejs kontrollieren (sollte 12.18 sein)
- aktuell sind nur die drei Adapter Admin, Discovery device und Info installiert
- umstellen auf latest.
-ioBroker Dienst stoppen
-ioBroker Eingabeaufforderung starten und js-controler nach bekannten Muster (update upgrade self) aktualsieren auf derzeit 3.1.5 - ioBroker Dienst wieder starten
- Admin aufrufen und die drei Adapter aktualisieren.
ALLE DREI ADAPTER LIEßEN SICH OHNE DAS BEKANNT node_modules LÖSCH PHÄNOMEN AKTUALISIEREN !!! - und das mit js-controller 3.1.5 !!!
...... to be continued
-
@P-A-L-A-D-I-N sagte in ioBroker unter Windows installieren (ohne Installer):
Das Problem läßt sich, zumindest meiner Erfahrung nach, mit jedem System, völlig unabhängig von den installierten Adaptern und Instanzen, reproduzieren! Auch ist es völlig gleich, wie die Installation durchgeführt worden ist (händisch oder Installer).
...Danke, das hilft schon mal.
-
@JB_Sullivan sagte in ioBroker unter Windows installieren (ohne Installer):
@P-A-L-A-D-I-N
Genau das ist nämlich bei mir nicht der Fall. nodejs ist als Version 12.18 installiert. ioB, behauptet aber immer noch, das es auf 10.17 unterwegs ist.Komisch! Wenn Du mit einem sauberen System startest und meine Anleitung (auch zum Updaten) genauestens befolgst, sollte das Ergebnis eigentlich immer das selbe sein: ein sauber laufendes, in allen Bereichen ganz aktuelles System (bis auf den js-controller)! Arbeitest Du mit einem nicht frisch aufgesetzten Rechner (Windows-Installer zuvor benutzt)? Würde mich, unabhängig davon, daß Du es mit dem Workaround jetzt wohl bereits hinbekommen hast, doch mal interessieren...
-
zu dem nodejs12.18 - hatte ich oben schon geschrieben - war mein Fehler.
Nein ist eine Windows Server Maschine - habe auf der Arbeit gerade ein bisschen Zeit und bin am rum probieren. Der WinInstaller ist jetzt schon ein paar mal gelaufen.
Ich deinstalliere allerdings immer alles nach jedem Versuch KOMPLETT (Phyton, GIT usw. - einfach alles wieder runter und den Dienst aus der Registry lösche ich auch)
-
Zu früh gefreut - wegen der Reproduzierbarkeit habe ich die Schritte wie oben EXAKT noch einmal ausgeführt - und Bingo - jetzt wurden wieder der nodes_modules Ordner einer "Säuberung" unterzogen.
Ich habe zwischendurch auch noch andere Dinge probiert. Das alles hier zu beschreiben, wäre zu viel des guten. Allerdings bin ich mitlerweile der Auffassung das der Fehler ein Zusammenspiel zwischen PHYTON und dem js-controller 3.xx ist.
Hauptverantwortlicher dürfte hierbei Phyton 2.7 sein - ich bin aber noch am testen.
-
@JB_Sullivan sagte in ioBroker unter Windows installieren (ohne Installer):
Hauptverantwortlicher dürfte hierbei Phyton 2.7 sein
Das kann nicht sein. Python hat rein gar nichts mit node_modules zu tun, außer dass es fürs Kompilieren mancher Module benötigt wird.
Wenn du es tatsächlich reproduzieren kannst und weißt, welcher Schritt die Module löscht, zeig mir bitte mal package.json, package-lock.json und .npmrc aus dem ioBroker-Ordner vor und nach dem tödlichen Schritt.
-
Ich hoffe ich habe es nicht übersehen, aber hat es schon jemand mit Node 10.x und js-controller 3.x versucht?
-
Folgende Schritte sind bei einem Update und Neuinstallation zwingend notwendig:
- data-Ordner sichern (nur bei Update)
- Alte Instanz stoppen
- Frische Installation mit dem Installer von der Webseite (2019-11-23) aufsetzen. Dabei (falls Update) den zuvor gesicherten data-Ordner durch den Installer einlesen mit der entsprechenden Option zur Migration.
- Nichts weiter tun!
- ioBroker-Konsole der neuen Installation auf
iobroker stop
npm i iobroker.js-controller@stable --ignore-scripts
- Zuvor gesicherten Ordner
iobroker-data
ins Installationsverzeichnis der neuen Instanz kopieren und alle vorhandenen Dateien überschreiben. - Wieder Konsole auf:
iobroker start
- ioBroker Admin ist unter der Adresse der alten Installation erreichbar (auch wenn Ports im Installer geändert wurden).
Edit: Test-Beschreibung gelöscht, weil von der Installer-Seite hierher verlinkt wird.
Edit2: Update-Vorgang nach Feedback durch @bahnuhr aktualisiert.
Edit3: Update-Vorgang mit Migration nach erneutem Test aktualisiert (Ordner kopieren, Port) -
Welchen der Installer hast du genommen?
-
@stefande Gibts mehrere?
-
@AlCalzone
Ach ich hab hier noch einige alte rumliegen.
Dazu kommen noch die sich noch in Arbeit befindlichen neuen von Stabilostick.
Ich werde im laufe des Tages auch mal eine VM aufsetzen und will dann nicht gleich mit einem falschen Installer starten. Aber jetzt weiß ich bescheid. -
@stefande Der auf der Webseite ist quasi "falsch", weil er einen JS-Controller installiert, der den bekannten Fehler provoziert.
Mitnpm i iobroker.js-controller@stable --ignore-scripts
ohne vorher irgendwas zu tun kann man diesen Fehler aber wohl vermeiden.