NEWS
Node.js Update im Docker
-
@haselchen sagte in Node.js Update im Docker:
sudo apt update && sudo apt full-upgrade && sudo apt autoremove
Danke und aktuell Version ist drauf.
Jetzt frage ich mich natürlich warum etwas anderes empfohlen wird, wenn es nicht funktioniert?
-
Weil diese Änderungen nicht persistent sind.
-
@haselchen sagte in Node.js Update im Docker:
sudo apt update && apt upgrade -y
kannst auch bequem den Befehl nehmen
sudo apt update && sudo apt full-upgrade && sudo apt autoremoveSiehe https://docs.buanet.de/iobroker-docker-image/docs/#updates-upgrades
Das macht man in Docker-Containern eigentlich nicht (weil dann hat man ja nicht mehr genau den Stand, welchen man mal geladen hat - und das ist ja der Sinn von Containern)
Note that the recommended way is always to simply pull the newest image and recreate your ioBroker Docker container.
-
Jetzt wird es verwirrend.
Was ist denn jetzt der richtige Weg im Docker?
-
@th-g sagte in Node.js Update im Docker:
Was ist denn jetzt der richtige Weg im Docker?
Neues, aktuelles Image ziehen.
-
Würde bedeuten, dass alle 2Wochen nen neues Image heruntergeladen werden müsste, weil sich die NodeVersion von z.B. 18.20.0 auf 18.20.1 ändert?
Das halte ich für absoluten Quark.
Ausserdem wird dieser Weg empfohlen, nicht vorgeschrieben.
Ich bin jetzt seit Jahren dabei und benutze den 2.IobrokerContainer.
Ich habe nicht die geringsten Schwierigkeiten mit dem Updaten des Containers.
Sei es JSController, Adapter oder Node.Aber um Mißverständnisse vorzubeugen:
Das ist MEINE Installation und Risiko. -
Für reine Anwender wie mich ist das natürlich nicht so gut, wenn es so unterschiedliche Aussagen gibt.
-
@haselchen sagte in Node.js Update im Docker:
Ich habe nicht die geringsten Schwierigkeiten mit dem Updaten des Containers.
Ist ja auch technisch kein Problem. Nur widerspricht das halt dem Konzept von Docker-Containern (LXC ist wieder was ganz anderes). Daher ja auch die Empfehlung in der Doku es nicht zu tun.
Spätestens wenn Du Major-Updates von nodejs machst ist ein neues Image sinnvoll. Sonst kann man sich das mit Docker auch komplett sparen
-
Die letzte Version von buanet ist 9.1.1 vom 24.01.24
Wie soll also der User an die aktuelle Node 18.20.1 kommen?Wenn ich da nen Denkfehler habe, korrigier mich bitte.
-
@haselchen Normalerweise müssten die Images regelmäßig neu gebaut werden. Aktuell passiert das scheinbar nur bei einem Release und nicht mit einem fixen Zeitplan:
- https://github.com/buanet/ioBroker.docker/actions/workflows/build-debian12-latest.yml
- https://github.com/buanet/ioBroker.docker/blob/main/.github/workflows/build-debian12-latest.yml
Da könnte man drüber sprechen, dass häufiger neue Images veröffentlicht werden sollten.
Die Idee von Docker ist ja, dass jeder eine identische Applikation in einer identischen Umgebung bekommt. Also auch die Pakete im Userland haben dann fixe Versionen. Lade ich heute das Image
iobroker/iobroker:v9.1.1
und in 2 Wochen auf einem anderen System, ist das Ergebnis exakt das gleiche. Und darum geht es ja: Reproduzierbarkeit und klar definierte Versionen.Das wird natürlich dadurch etwas verwässert, dass man mit weiteren Env-Variablen des Containers auch Pakete hinzufügen kann oder sogar ein Update anstoßen kann.
-
Da hast Du jetzt schön Docker bzw. Container erklärt, aber keine Antwort auf meine Frage geliefert
Die letzte Version von buanet ist 9.1.1 vom 24.01.24 Wie soll also der User an die aktuelle Node 18.20.1 kommen?
Du glaubst doch nicht ernsthaft, dass der Entwickler mit jeder kleinen Node Änderung nen Image rausbringt.
André schreibt auf seiner Seite selber:
..... oder die Nodejs-Version manuell innerhalb des Containers UpdatenSei es wie es ist...wir haben eine Grauzone und jeder soll selber entscheiden, wie er bei einem Update vorgeht.
-
@haus-automatisierung sagte in Node.js Update im Docker:
Da könnte man drüber sprechen, dass häufiger neue Images veröffentlicht werden sollten.
Es wurde bisher immer das latest Image mit der jeweils aktuellen Nodejs Version regelmäßig neu gebaut. In der Erkennung war aber ein Fehler, den André gerade behebt. Heute Abend soll es ein aktualisiertes Image geben.
EDIT: @th-g Deine Methode war also absolut korrekt und auch so empfohlen.
-
@haselchen sagte in Node.js Update im Docker:
Du glaubst doch nicht ernsthaft, dass der Entwickler mit jeder kleinen Node Änderung nen Image rausbringt.
Soll ich jetzt best practices für Docker verlinken? Natürlich beantwortet das nicht die Frage, wie man die neueste Node-Version kommt. Aber das stört dich bei anderen Paketmanagern ja auch nicht, oder?
Wenn Du einen beliebigen Adapter installierst, bringt der ebenfalls über die package.json eine Liste der Pakete + der gewünschten Version mit. Sind die Abhängigkeiten immer top aktuell? Nein. Ist das nötig? In den meisten Fällen wohl nicht.
In meinen Augen gibst Du mit der Verwendung des Docker-Images das Abhängigkeitsmanagement in die Hände des Entwicklers, welche die Container bereitstellt und musst dich nicht mehr darum kümmern. Nur, dass das Image aktuell gehalten wird. Genau wie bei ioBroker-Adaptern auch jemand anders für Dich die Pakete aktualisiert.
-
@haselchen sagte in Node.js Update im Docker:
Sei es wie es ist...wir haben eine Grauzone und jeder soll selber entscheiden, wie er bei einem Update vorgeht.
Eben!
Docker-Container sind eigentlich nicht dazu gedacht, damit dauerhaft ein bestimmtes System zu betreiben.
Das sind Wegwerfartikel. Benutzen, verwerfen, neu aufsetzen.
Kollegen von mir ziehen scriptgesteuert in der Cloud 'ne komplette Infrastruktur für ihr Build hoch und werfen das anschließend komplett weg.Darum muss in einem Container auch eigentlich nix manuell aktualisiert werden.
Wer's trotzdem machen möchte: Ist ja nicht verboten, sondern lediglich "nicht empfohlen".Solange der Container läuft, ist ja auch alles tutti.
Erst wenn man den Container verwirft und aus dem Image neu erstellt, sind die in der Zwischenzeit aktualisierten Pakete wieder auf dem ursprünglichen Stand.
Muss man halt wissen ... um sich dann im Fall der Fälle nicht zu fragen, warum. -
@th-g sagte in Node.js Update im Docker:
Hallo,
ich halte mich an die Vorgaben so wie nachfolgend beschrieben
Docker: https://docs.buanet.de/de/iobroker-docker-image/docs/#wartung,
aber Node.js wird nicht auf die aktuelle Version von 18.20.0 auf 18.20.1 upgedatet.
Was muss ich tun?
Danke
Der Trick liegt daran den entsprechenden Abschnitt komplett zu lesen insbesondere des letzten absatzes. Speziell zu Node stand da eigentlich nix mehr oder hab ich da was übersehen?
Linux System Pakete aktualisieren
Die im ioBroker Docker Image enthaltenen Linux Pakete lassen sich manuell über den integrierten Paketmanager apt aktualisieren. Dabei unterscheidet sich die Vorgehensweise nicht von der anderer auf Debian basierender Linux Systeme und erfolgt über die Kommandozeile des Containers.Beachte, dass der empfohlene Weg allerdings das Herunterladen des aktuellen ioBroker Docker Images und anschließende Neuerstellen des Containers ist.
-
Wie lange dauert es in der Regel bis eine Versionen im latest Docker ist? Versuche seit zwei Tagen meinen Docker neu zu erstellen um auf die neue Node.js 20.15.1 Version zu kommen aber es ist immer noch die alte im Image.
-
du kannst hier schauen, wann welches "image" unter welchem tag veröffentlicht wurde.
wenn du das absolut letzte image abrufen willst, dann könntest du
buanet/iobroker:beta-node22
im docker angeben. das ist 5h alt.das letzte offizielle latest (mit v9) ist 5 Tage alt.
-
@oliverio sagte in Node.js Update im Docker:
buanet/iobroker:beta-node22
node 22 ist aktuell nicht empfohlen und könnte mit einigen Adaptern Probleme machen.
-
@haus-automatisierung sagte in Node.js Update im Docker:
@oliverio sagte in Node.js Update im Docker:
buanet/iobroker:beta-node22
node 22 ist aktuell nicht empfohlen und könnte mit einigen Adaptern Probleme machen.
richtig, wie alle Beta-Versionen, bitte beachten VOR dem Installieren.. (und backup machen und so.. ne.. )
Ich hab mal gewagt, nachdem ich ein paar Tests aufm Raspi gemacht habe, mein produktives Docker mit der V10-beta1-Node-22 laufen zu lassen, und siehe da, es funktioniert... diese Adapter laufen bei MIR unter Node 22... muss man nicht nachmachen.. :
iobroker@iobroker:~$ iob update Used repository: beta Adapter "accuweather" : 1.5.0 , installed 1.5.0 Adapter "admin" : 7.0.16 , installed 7.0.16 Adapter "alarm" : 3.6.1 , installed 3.6.1 Adapter "alexa2" : 3.26.5 , installed 3.26.5 Adapter "backitup" : 3.0.9 , installed 3.0.9 Adapter "bluelink" : 2.3.6 , installed 2.3.8 Adapter "cloud" : 5.0.1 , installed 5.0.1 Adapter "countdown" : 2.2.0 , installed 2.2.0 Adapter "device-watcher": 2.12.1 , installed 2.12.1 Adapter "devices" : 1.1.5 , installed 1.1.5 Adapter "deyeidc" : 0.0.14 , installed 0.0.14 Adapter "email" : 1.3.1 , installed 1.3.1 Adapter "energiefluss" : 3.6.0 , installed 3.6.0 Adapter "feiertage" : 1.2.0 , installed 1.2.0 Adapter "fitbit-fitness": 0.5.0 , installed 0.5.0 Adapter "frigate" : 1.2.1 , installed 1.2.1 Adapter "fritzdect" : 2.5.9 , installed 2.5.9 Adapter "fullybrowser" : 3.0.12 , installed 3.0.12 Adapter "go-e" : 1.0.36 , installed 1.0.36 Adapter "govee-local" : 0.2.6 , installed 0.2.6 Adapter "heizoel" : 1.0.3 , installed 1.0.3 Adapter "ical" : 1.15.0 , installed 1.15.0 Adapter "influxdb" : 4.0.2 , installed 4.0.2 Adapter "iot" : 3.3.0 , installed 3.3.0 Adapter "javascript" : 8.6.0 , installed 8.6.0 Controller "js-controller": 6.0.8 , installed 6.0.8 Adapter "lg-thinq" : 1.0.1 , installed 1.0.1 Adapter "lgtv" : 2.2.0 , installed 2.2.0 Adapter "linux-control": 1.1.5 , installed 1.1.5 Adapter "meteoalarm" : 3.0.2 , installed 3.0.2 Adapter "mihome-vacuum": 4.2.0 , installed 4.2.0 Adapter "minuvis" : 2.3.3 , installed 2.3.3 Adapter "mqtt" : 6.0.0 , installed 6.0.0 Adapter "notification-manager": 1.1.2, installed 1.1.2 Adapter "notificationforandroidtv": 3.0.4, installed 3.0.4 Adapter "nut" : 1.6.0 , installed 1.6.0 Adapter "odl" : 3.0.1 , installed 3.0.1 Adapter "oilfox" : 4.3.0 , installed 4.3.0 Adapter "ping" : 1.6.2 , installed 1.6.2 Adapter "pollenflug" : 1.0.6 , installed 1.0.6 Adapter "proxmox" : 2.3.0 , installed 2.3.0 Adapter "reolink" : 1.1.0 , installed 1.1.0 Adapter "rest-api" : 2.0.3 , installed 2.0.3 Adapter "shelly" : 7.0.0 , installed 7.0.0 Adapter "simple-api" : 2.8.0 , installed 2.8.0 Adapter "snmp" : 3.2.0 , installed 3.2.0 Adapter "socketio" : 6.7.1 , installed 6.7.1 Adapter "solarmanpv" : 0.5.1 , installed 0.5.1 Adapter "sonoff" : 3.1.0 , installed 3.1.0 Adapter "synology" : 3.1.0 , installed 3.1.0 Adapter "telegram" : 3.8.0 , installed 3.8.0 Adapter "tr-064" : 4.3.0 , installed 4.3.0 Adapter "trashschedule": 3.3.0 , installed 3.3.0 Adapter "tuya" : 3.15.0 , installed 3.15.0 Adapter "unifi" : 0.7.0 , installed 0.7.0 Adapter "uv-protect" : 0.6.0 , installed 0.6.0 Adapter "viessmannapi" : 2.4.0 , installed 2.4.0 Adapter "vis" : 1.5.6 , installed 1.5.6 Adapter "weatherunderground": 3.7.0, installed 3.7.0 Adapter "web" : 6.3.0 , installed 6.3.0 Adapter "wifilight" : 1.2.2 , installed 1.2.2 Adapter "windows-control": 0.1.5 , installed 0.1.5 Adapter "wled" : 0.7.3-beta.0, installed 0.7.3-beta.0 Adapter "worx" : 3.0.2 , installed 3.0.2 Adapter "ws" : 2.6.2 , installed 2.6.2 Adapter "yahka" : 1.0.3 , installed 1.0.3 Adapter "yeelight-2" : 1.4.0 , installed 1.4.0 Adapter "zigbee" : 1.10.3 , installed 1.10.3 iobroker@iobroker:~$
-
@ilovegym sagte in Node.js Update im Docker:
diese Adapter laufen bei MIR unter Node 22
Ich denke auch, dass 95% der Adapter keine Probleme machen werden. Dennoch ist das mit Vorsicht zu genießen und man sollte sich in dem Rahmen bewegen, welcher offiziell getestet wurde. Und ich habe z.B. noch keinen meiner Adapter unter node 22 getestet.