NEWS
[HowTo] ioBroker unter Docker auf Synology DiskStation
-
Hallo Andre,
ich bin zur Zeit im Osterurlaub, und habe nur beschränkten Zugriff auf mein Heimnetzt und heute spinnt die VPN Verbindung total, Urlaub auf dem Land halt
Andere Images habe ich da nicht laufen, habe Docker erst durch deine Anleitung entdeckt.
Ich hatte die Einstellungen und den Container Inhalt über Export gesichert.
Kann ich diese Sicherung für die Advanced Schritte verwenden?
Diese Sicherung habe ich auch nach der Neuinstallation von Docker wieder Importiert, aber der Container läuft selbst nach x Neustarts nicht an.
Ich glaube im Protokoll stand sowas von, das er die iobroker Start .sh nicht öffnen konnte, müsste ich nochmal genau schauen.
DSM Version ist die aktuelle.
Docker weiß ich nur, das es die Tage mal ein Update gab, weil ich die Hoffnung hatte, das sich die bis zu 5 maligen Neustarts erledigen würde.
Gruß
Gingo79
15.04.17 Edit:
DSM Version: DSM 6.1-15047 Update 2
Docker: 1.11.2-0325
Ist das normal, wenn ich die Einstellungen importiert habe, das mir das unter Abbild als neues Image angezeigt wird?
Mit dem Protokoll und der Start.sh hatte ich falsch im Kopf, an folgendes hapert es wohl irgendwie:
Failed to Start message bus: Failed to bind socket „/var/run/dbus/system_bus_socket“: Address already in use
Was ist jetzt das Problem bzw. der Fehler?
Wie komme ich überhaupt an diesen Pfad dran?
Ich hoffe du kannst damit was anfangen:)
habe mal zum Testen openhab2 eingespielt, paar mal neu restartet, und läuft bisher immer sauber an.
-
Hallo Andre,
ich bin zur Zeit im Osterurlaub, und habe nur beschränkten Zugriff auf mein Heimnetzt und heute spinnt die VPN Verbindung total, Urlaub auf dem Land halt
Andere Images habe ich da nicht laufen, habe Docker erst durch deine Anleitung entdeckt.
Ich hatte die Einstellungen und den Container Inhalt über Export gesichert.
Kann ich diese Sicherung für die Advanced Schritte verwenden? `
Das sollte gehen. In der Theorie etwa so:-
neuen, frischen Container aufsetzen
-
im blanken ioBroker Backup wiederherstellen (ggf. Adapter installieren?)
-
wenn alles läuft, ioBroker stoppen und den gesamten Ordner /opt/iobroker sichern bzw. auf die DS verschieben
-
dann Container stoppen und Ordner einhängen
-
Container starten
@gingo79:
Diese Sicherung habe ich auch nach der Neuinstallation von Docker wieder Importiert, aber der Container läuft selbst nach x Neustarts nicht an.
Ich glaube im Protokoll stand sowas von, das er die iobroker Start .sh nicht öffnen konnte, müsste ich nochmal genau schauen.
DSM Version ist die aktuelle.
Docker weiß ich nur, das es die Tage mal ein Update gab, weil ich die Hoffnung hatte, das sich die bis zu 5 maligen Neustarts erledigen würde.
Gruß
Gingo79
15.04.17 Edit:
DSM Version: DSM 6.1-15047 Update 2
Docker: 1.11.2-0325
Ist das normal, wenn ich die Einstellungen importiert habe, das mir das unter Abbild als neues Image angezeigt wird?
Mit dem Protokoll und der Start.sh hatte ich falsch im Kopf, an folgendes hapert es wohl irgendwie:
Failed to Start message bus: Failed to bind socket „/var/run/dbus/system_bus_socket“: Address already in use `
Klingt für mich nach bereits belegtem Port. Kann es sein, dass irgendwas auf der DS einen ioBroker Standardport bereits belegt? interessannt sind dabei die Ports 8082, 9000 und 9001. Läuft vielleicht ein Logitech Media Server oder OSCAM?
@gingo79:Was ist jetzt das Problem bzw. der Fehler?
Wie komme ich überhaupt an diesen Pfad dran?
Ich hoffe du kannst damit was anfangen:)
habe mal zum Testen openhab2 eingespielt, paar mal neu restartet, und läuft bisher immer sauber an. `
MfG,
André
-
-
Das sollte gehen. In der Theorie etwa so:
-
neuen, frischen Container aufsetzen
-
im blanken ioBroker Backup wiederherstellen (ggf. Adapter installieren?)
-
wenn alles läuft, ioBroker stoppen und den gesamten Ordner /opt/iobroker sichern bzw. auf die DS verschieben
-
dann Container stoppen und Ordner einhängen
-
Container starten `
Hallo Andre,
das kann doch nicht so schwer sein und doch komme ich nicht weiter, wo finde ich denn den Ordner /opt/iobroker und wie klappt das dann mit dem verschieben/sichern?
Klingt für mich nach bereits belegtem Port. Kann es sein, dass irgendwas auf der DS einen ioBroker Standardport bereits belegt? interessannt sind dabei die Ports 8082, 9000 und 9001. Läuft vielleicht ein Logitech Media Server oder OSCAM?
MfG,
André `
Ne beides läuft nicht auf der DS und kann auch nichts anderes finden, was die Ports belegt auf der DS
Gruß
Gingo79
-
-
Hallo André,
Ich habe im frischen Container die Einstellungen importiert, dabei hat er unter Abbild ein neues Image erstellt. Ich hoffe mal das es richtig so ist?
Wenn ich den Starte, kommt folgende Fehlermeldung und der iobroker startet nicht.
rm: cannot remove '/var/run/dbus/pid': No such file or directory
stdout
12:17:00
Failed to start message bus: Failed to bind socket "/var/run/dbus/system_bus_socket": Address already in use
stdout
12:17:00
[….] Stopping Avahi mDNS/DNS-SD Daemon: avahi-daemon [?25l 7 [1G[ [32m ok [39;49m 8 [?12l [?25h.
stdout
12:17:00
[….] Starting Avahi mDNS/DNS-SD Daemon: avahi-daemon [?25l 7 [1G[ [31mFAIL [39;49m 8 [?12l [?25h [31mfailed! [39;49m
stdout
12:17:01
iobroker controller daemon already running. PID: 64
Beim Instalieren von Docker auf volume1, hat er automatisch einen unter File Station sichtbaren Ordner "docker" erstellt.
Dieser befindet sich komischer Weise im volume3 und ist leer.
Ich hoffe die Infos helfen etwas weiter.
Danke und Gruß
Gingo79
-
Hallo André,
Ich habe im frischen Container die Einstellungen importiert, dabei hat er unter Abbild ein neues Image erstellt. Ich hoffe mal das es richtig so ist?
Wenn ich den Starte, kommt folgende Fehlermeldung und der iobroker startet nicht.
rm: cannot remove '/var/run/dbus/pid': No such file or directory
stdout
12:17:00
Failed to start message bus: Failed to bind socket "/var/run/dbus/system_bus_socket": Address already in use
stdout
12:17:00
[….] Stopping Avahi mDNS/DNS-SD Daemon: avahi-daemon [?25l 7 [1G[ [32m ok [39;49m 8 [?12l [?25h.
stdout
12:17:00
[….] Starting Avahi mDNS/DNS-SD Daemon: avahi-daemon [?25l 7 [1G[ [31mFAIL [39;49m 8 [?12l [?25h [31mfailed! [39;49m
stdout
12:17:01
iobroker controller daemon already running. PID: 64
Beim Instalieren von Docker auf volume1, hat er automatisch einen unter File Station sichtbaren Ordner "docker" erstellt.
Dieser befindet sich komischer Weise im volume3 und ist leer.
Ich hoffe die Infos helfen etwas weiter.
Danke und Gruß
Gingo79 `
OK, ich glaube ich war auf dem falschen Weg… Ich hatte angenommen, dass du ein Backup (Export) über ioBroker gemacht hast (http://www.iobroker.net/docu/?page_id=2380&lang=de, erste Frage).
Wenn ich das jetzt richtig interpretiere, dann hast du aber einen Export über Docker auf der DS gemacht, oder?
Mit welchen Optionen? Nur Containereinstellungen oder auch Inhalt?Nur Einstellungen reicht nicht aus. Darin sind keine ioBroker-Daten, sondern nur die Einstellungen des Docker-Containers selbst, also Ports, eingehängte Ordner usw… Du hättest nach dem Wiederherstellen also eine leere ioBroker Standardinstallation...
Ich habe mir eben übrigens gerade mal das Image über Docker neu gezogen (> Registrierung > Image suche > Download > warten).
Wenn ich daraus dann einen Container starte bekomme ich in der Tat ein ähnliches Log wie du. Irgendetwas mit dem Avahi-Daemon scheint nicht zu stimmen. Aber wie es die letzte Logzeile eigentlich sagt, startet/ läuft iobroker trotzdem. Das ist bei mir auch der Fall.
Was sagt denn ein:
cd /opt/iobroker iobroker status
im Terminal des neu erstellten Docker Containers?
Ich werde mich jetzt mal um den Avahi Daemon kümmern und das Image anpassen.
[EDIT] Ich habe mir das Avahi-Thema einmal angeschaut. Es scheint als könnte man in Docker nur einen Container laufen haben, der den Avahi ausführt. In meinem Test oben, hatte ich einen zweiten Container zum Testen erstellt…
Wie auch immer, ich habe meinen "produktiv"-Container kurzerhand auf das aktuelle Image aktualisiert... Das Log sah nach dem ersten Start so aus:
2017-04-18 07:54:54,stdout,rm: cannot remove '/var/run/dbus/pid': No such file or directory 2017-04-18 07:54:55,stdout,[....] Stopping Avahi mDNS/DNS-SD Daemon: avahi-daemon[?25l7[1G[[32m ok [39;49m8[?12l[?25h. 2017-04-18 07:54:55,stdout,[....] Starting Avahi mDNS/DNS-SD Daemon: avahi-daemon[?25l7[1G[[32m ok [39;49m8[?12l[?25h. 2017-04-18 07:54:56,stdout,Starting iobroker controller daemon... 2017-04-18 07:54:57,stdout,iobroker controller daemon started. PID: 66
Es liefen alle Dienste, inklusive des Avahi, einwandfrei an. Das aktuelle Image ist also ok.
MfG,
André
-
Hallo Andre,
genau, ich habe einen Export über Docker auf der DS gemacht und zwar Containerinhalt und -einstellungen exportieren.
Wenn ich diesen unter Container über Einstellungen Importiere, produziert er mir unter Abbild ein neues Image und beim starten kommt die Meldung, wie ich bereits in meinen vorherigen Post es eingefügt habe.
Wenn ich im Terminal des neu erstellten Containers
cd /opt/iobroker
iobroker Status
einegebe, dann kommt
„iobroker is not running“
Da iobroker ja eh nicht am laufen ist und nicht weiter komme, habe ich ein Backup im Terminal über iobroker mit ./iobroker backup gemacht.
Backup created: /opt/iobroker/backups/2017_04_18-15_39_178_backupiobroker.tar.gz
Hat geklappt, aber wie komme ich jetzt an diese Datei dran bw wie kann ich die verschieben, ich finde sie nirgends und kann ich diese dann irgendwie für das Mounten Benutzen /Advanced Schritte benutzen?
Habe ich so vielleicht noch eine Chance?
Denn das Importieren wie oben klappt ja nicht.
Also wie komme ich auf /opt/iobroker damit ich das sicher kann.
Wenn es geht, bitte für einen Anfänger in kleinen Schritten. Danke
gruß
Gingo79
-
du könntest dir in deinem Dockerimage noch den Midnightcommander installieren. (Für alle die DOS großgeworden sind ist der Begriff Nortoncommander sicher noch ein Begriff)
Auch wenn dir der Begriff nichts sagt - dieses Programm bietet eine sehr einfache Möglichkeit ohne Linuxkentnisse Dateien zu verschieben, kopiern, …
Du kannst es im Terminal mittels
apt-get install mc
installieren und dann mit````
mcVoraussetztung dass du die Daten aus dem Image herausbekommst ist natürlich ein gemountetes Verzeichnis ausserhalb von Docker. LG Schubi [1904_unbenannt2.jpg](/assets/uploads/files/1904_unbenannt2.jpg)
-
Da iobroker ja eh nicht am laufen ist und nicht weiter komme, habe ich ein Backup im Terminal über iobroker mit ./iobroker backup gemacht.
Backup created: /opt/iobroker/backups/2017_04_18-15_39_178_backupiobroker.tar.gz
Hat geklappt, aber wie komme ich jetzt an diese Datei dran bw wie kann ich die verschieben, ich finde sie nirgends und kann ich diese dann irgendwie für das Mounten Benutzen /Advanced Schritte benutzen?
Habe ich so vielleicht noch eine Chance?
Denn das Importieren wie oben klappt ja nicht.
Also wie komme ich auf /opt/iobroker damit ich das sicher kann.
Wenn es geht, bitte für einen Anfänger in kleinen Schritten. Danke `
OK. Nichts leichter als das. Also um die Backup-Datei vom container auf die DS zu bekommen benötigst du ein gemountetes Verzeichnis in das du die Datei dann hinein kopierst. Beispiel:
Im Terminal des Containers einen Transfer-Ordner erstellen
mkdir /opt/transfer
Dann den Container stoppen und bearbeiten um ein Verzeichnis zu mounten, dabei ein Verzeichnis auf der DS auswählen und dann den Pfad des Transfer-Ordner im Container eingeben
Dann Container wieder starten und die Backup-Datei per Terminal in das Verzeichnis kopierencp /opt/iobroker/backups/2017_04_18-20_16_01_backupiobroker.tar.gz /opt/transfer/2017_04_18-20_16_01_backupiobroker.tar.gz
(Den Dateinamen natürlich entsprechend anpassen). Damit liegt dann die Datei auf de DS im entsprechend gemounteten Verzeichnis.
Für die Wiederherstellung würde ich dann einen komplett neuen Container aus dem Image heraus starten und prüfen ob die Dienste laufen. Dann die Kopier-Prozedur nochmal in die andere Richtung. Also Ordner anlegen, Container stoppen und bearbeiten, Container starten, Backupdatei vom Transferordner ins ioBroker-Backup-Verzeichnis kopieren…
Anschließend im Terminal:
cd /opt/iobroker iobroker restore 0
(https://github.com/ioBroker/ioBroker/wi … ker-backup)
Anschließend prüfen ob der Restore erfolgreich war und ioBroker erstmal wieder zum laufen bekommen.
Wenn das geklappt hat, kann man über die gleiche Verfahrensweise (per gemountetem Verzeichnis) nicht nur die einzelne Backup-Datei, sondern den gesamten ioBroker-Ordner auf die DS kopieren. Anschließend das Zielverzeichnis auf der DS in /opt/iobroker mounten und schon liegen die ioBroker-Daten auf der DS und der Container ist nur noch die "Ausführungsumgebung".
Aktuell bin ich gerade dabei eine ausführliche Anleitung für ioBroker auf Synology DS zu schreiben. Da ist auch dieser Punkt drin. Kann allerdings noch nicht sagen wann ich die raus lassen kann…
Ich hoffe das hilft so erstmal weiter. Sonst muss ich mal auf anderem Wege ein wenig Nachhilfe geben. Hatte eh mal überlegt soetwas wie eine Websession zu machen...
Bitte mal Wortmeldung falls das für euch interessant wäre. (Bin allerdings auch erst vor wenigen Wochen in das Docker Thema rein gewachsen)
MfG,
André
-
Hallo André,
super Danke, jetzt sind ein paar Wissens Lücken gestopft.
Werde damit mal experimentieren.
Was muss ich denn im Container Terminal eingeben, um das Verzeichnis /opt/iobroker zu kopieren?
Gruß
Gingo79
-
Mit der Option -r werden auch die Unterverzeichnisse kopiert:
cp -r /opt/iobroker /opt/transfer
-
Yuppie, Backup einspielen hat geklappt und iobroker läuft!
Vielen Dank Andre!
Komisch das dies nicht über Container Sichern klappte.
Jetzt habe ich nur das Problem, das der Adpter VIS nicht anläuft.
Beim Aufrufen der Seite kommt: File edit.html Not found: Not exists
Gibt es da auch noch was schönes, was ich übern Terminal machen kann?
Gruß
Gingo79
-
Yuppie, Backup einspielen hat geklappt und iobroker läuft!
Vielen Dank Andre!
Komisch das dies nicht über Container Sichern klappte.
Jetzt habe ich nur das Problem, das der Adpter VIS nicht anläuft.
Beim Aufrufen der Seite kommt: File edit.html Not found: Not exists
Gibt es da auch noch was schönes, was ich übern Terminal machen kann?
Gruß
Gingo79 `
Schön dass es geklappt hat.Was vis angeht würde ich mal im Forum suchen.
Vielleicht hilft es vis nochmal neu zu installieren.
MfG,
Andre
Gesendet von meinem D5803 mit Tapatalk
-
Hallo Andre,
nachdem ich die Adapter teilweise mehrmals neu Instaliert habe, läuft iobroker nun den 2. Tag Stabil und ich konnte alle meine Daten retten und wieder neu einspielen.
Selbst das Verzeichniss /opt/iobroker ist jetzt gemountet.
Nach dem morgentlichen Erwachen der DS, läuft iobroker auch sauber an.
Ich denke, das Start Protokoll sieht jetzt auch gut aus, oder?
[....] Stopping Avahi mDNS/DNS-SD Daemon: avahi-daemonProcess 40 died: No such process; trying to remove PID file. (/var/run/avahi-daemon//pid) [?25l7[1G[[32m ok [39;49m8[?12l[?25h. [....] Starting Avahi mDNS/DNS-SD Daemon: avahi-daemon[?25l7[1G[[32m ok [39;49m8[?12l[?25h. Starting iobroker controller daemon... iobroker controller daemon started. PID: 66
Nochmal ein riesen Dank.
mfg
gingo79
-
Hallo Andre,
nachdem ich die Adapter teilweise mehrmals neu Instaliert habe, läuft iobroker nun den 2. Tag Stabil und ich konnte alle meine Daten retten und wieder neu einspielen.
Selbst das Verzeichniss /opt/iobroker ist jetzt gemountet.
Nach dem morgentlichen Erwachen der DS, läuft iobroker auch sauber an.
Ich denke, das Start Protokoll sieht jetzt auch gut aus, oder?
[....] Stopping Avahi mDNS/DNS-SD Daemon: avahi-daemonProcess 40 died: No such process; trying to remove PID file. (/var/run/avahi-daemon//pid) [?25l7[1G[[32m ok [39;49m8[?12l[?25h. [....] Starting Avahi mDNS/DNS-SD Daemon: avahi-daemon[?25l7[1G[[32m ok [39;49m8[?12l[?25h. Starting iobroker controller daemon... iobroker controller daemon started. PID: 66
Nochmal ein riesen Dank.
mfg
gingo79 `
Hört sich gut an und sieht auch gut aus. Freut mich dass es geklappt hat.Ich habe übrigens kürzlich auf Guthaben (https://github.com/buanet/docker-iobroker) unter Scripts schonmal ein Backup-Script hinzugefügt, welches jetzt dann auch im Docker Container unter /opt/scripts liegen sollte.
Mit dem Script kann man ein Backup des ioBroker Ordners auf der DS erzeugen. Dazu wird sogar der Container gestoppt und wieder gestartet. Ist zwar noch nicht "offiziell" dokumentiert, funktioniert aber bei mir schon super.
Eine kurze Anleitung zum Script steht direkt in der Datei. Ansonsten muss halt das Script auf die DS kopiert werden, Pfade editieren und dann über den Aufgabenplaner der DS regelmäßig ausgeführt werden. Relativ simpel eigentlich…
Vielleicht ja auch was für dich. Backup ist ja meist der nächste Schritt wenn einmal läuft
MfG, Andre
Gesendet von meinem D5803 mit Tapatalk
-
Hallo Andre,
habe das Script gefunden…aber was meinst Du genau damit, das es unter /opt/script liegen sollte.
Wenn ich das genau verstanden habe, muss ich folgende Schritte machen:
-
im Script die Pfade anpassen
-
auf der DS - Aufgabenplaner - Erstellen - Geplante Aufgabe - Benutzerdefiniertes Script
-
Script einfügen, Zeitplan wöchentlich einstellen
und das war es?
gruß
gingo79
-
-
Hallo,
wie binde ich ein iOBroker Verzeichnis ein, welches schon auf der DS ist?
Bitte für einen erklären, der keine Ahnung von Linux hat.
Ich habe unter File Station ein Docker-Verzeichnis. Da ist aber nichts drin.
Also komme ich nicht auf docker/iobroker.
-
Ich habe jetzt das iobroker-Verzeichnis in das Docker-Verzeichnis kopiert.
Dann habe ich auf das iOBroker-Verzeichnis (bei mir unter /homes/admin/opt/iobroker) gemountet.
Jetzt kommt keine Fehlermeldung mehr.
Sollte jetzt aber nicht auf der Admin-Oberfläche alle schon installierten Pakete angezeigt werden?
Oder muss ich die alle neu installieren?
-
Wenn ich von /docker/iobroker auf opt/iobroker mounte, wo finde ich dann den Ordner opt?
Bekomme die Fehlermeldung "sh: 0: Can't open /opt/iobroker/startup.sh".
Kann mir bitte jemand helfen?
Habe die ganzen Beiträge bestimmt schon 10x gelesen.
Und alles ausprobiert.
Raffe es einfach nicht. Oder ich mache etwas verkehrt?
Hatte mein iOBroker sonst nicht im Docker laufen.
Da mir aber die Synology komplett abgeschmiert war und ich froh war, dass ich mit fremder Hilfe, meine Daten wieder herstellen konnte,
habe ich mir gedacht, dass ich jetzt den Docker ausprobiere.
Meine iOBroker-Ordner sind noch erhalten.
Habe diese Ordner in das docker-Verzeichnis, welches auf Volume2 erstellt wurde, kopiert.
Und dann, wie oben beschrieben, gemountet.
Gruss Superdad
-
Hallo,
dann will ich's mal versuchen
Wenn ich von /docker/iobroker auf opt/iobroker mounte, wo finde ich dann den Ordner opt? `
Der Ordner /opt/iobroker befindet sich dann im Docker Container. Also das Verzeichnis auf der DiskStation (in deinem Fall …/volume2/docker/iobroker) beinhaltet die ioBroker Installation, welche im Docker Container unter dem Pfad /opt/iobroker/ zur Verfügung steht.Wenn du im Terminal des Docker Containers einmal folgendes eingibst:
cd /opt/iobroker ls
Dann sollte das in etwa so aussehen:
Dort siehst du dann warscheinlich auch, dass dir die Datei startup.sh fehlt. Was uns dazu führt…Bekomme die Fehlermeldung "sh: 0: Can't open /opt/iobroker/startup.sh". `
Diese Datei wird benötigt, damit ioBroker nach dem Start des Containers startet. Im Normalfall kommt diese Datei mit dem Image aus dem man den Container startet mit. Da du aber deine alte ioBroker-Installation übernimmst, gibt es die Datei dort nicht. Ist aber kein Problem. Du kannst sie dir bei Github ziehen und dann in deinen ioBroker Ordner auf der DS (…/volume2/docker/iobroker) kopieren:
https://github.com/buanet/docker-iobrok … startup.sh
(Von mir aus kannst du auch eine neue Datei mit selben Namen anlegen und nur den Inhalt hinein kopieren…)
Das sollte es schon gewesen sein. Container starten und dann mal schauen ob die Prozesse alle anlaufen...
Viel Erfolg.
MfG,
André
-
Vielen Dank!
Es funktioniert!
Und ich habe nach der startup.sh immer in opt/iobroker geschaut.
Mir ist nicht aufgefallen, dass die in docker/iobroker fehlt!
Kenn mich ebend mit Linux nicht so aus.
Vielen Dank und Gruss
Superdad