NEWS
Redis in ioBroker - Überblick
-
@uwerlp Siehe ooben. Wenn die klast des js.controller ok ist dann nichts tun. Alles gut
-
@apollon77 Im Htop sehe ich für iobroker.js-controller ständig wechselnde Werte von 8...80 CPU% im Mittel aber etwa 35. Für das Gesamtsystem wird Load average: 1,12 1,21 1,28 angezeigt. Habe vier Kerne.
Ist da jetzt der Wechsel empfohlen? -
@rushmed Ich würde sagen das ist ok - es sei denn Du siehst Performanceissues bei der Nutzung
-
@apollon77 Klar könnte alles schneller sein aber ich bin sehr zufrieden, vor allem wegen der Satbilität.
Danke für den Rat. -
Hallo,
ich bin gerade dabei, mit meinem Qnap alles in Container zu verschieben. Dazu eine Frage.
Ich habe Iobroker + Iobroker Slave auf einem Raspberry und möchte zukünftig mit redis auch Nextcloud im Container betreiben.Kann ich das alles mit einem installierten Rediscontainer machen?
Danke Bert
-
@bert-0 sagte in Redis in ioBroker - Überblick:
Kann ich das alles mit einem installierten Rediscontainer machen?
Klar ... Am Ende ist dieser Redis dann der neue "Master" im ioBroker System ...
-
@bert-0 sagte in Redis in ioBroker - Überblick:
Kann ich das alles mit einem installierten Rediscontainer machen?
du möchtest eine Redis-Instanz für iobroker und Nextcloud nutzen? Dann achte einfach darauf, dass du bei Nextcloud in der Redis-Config einen "dbindex" > "0" einträgst - dann kommen sich die beiden nicht in die Quere (afair hat Redis im Default 16 "Datenbanken" konfiguriert, ohne weitere Angaben landet man üblicherweise in DB "0". Da dürfte dann der iobroker drin sein...)
-
Danke euch beiden. Ich werde nach Weihnachten mich mal ans Werk machen.
Falls das mit der Redisdatenbank schief läuft, ist das ja überiobroker setup custom
wieder rückgängig zu machen?
Hoffe das es klappt, da das Antwortverhalten beim Iobroker schon grenzwertig ist ( Der Info TAB weist mich darauf hin, dass ich mehr als 30000 Objekte habe) und bei Nextcloud ausserhalb des Containers der Aufwand immer größer und dort die Anhebung der PHP Version mit QNAP immer schwieriger wird.Bert
-
@bert-0 Ja geht alles wieder rückgängig zu machen
-
@bert-0 sagte in Redis in ioBroker - Überblick:
Kann ich das alles mit einem installierten Rediscontainer machen?
Ich betreibe das genau so, und wie @JLeg schrieb, Nextcloud einfach in den DB1 schieben, dann sind die Daten sauber getrennt.
In der config.php sieht das dann so (oder ähnlich) aus:
'memcache.local' => '\\OC\\Memcache\\Redis', 'memcache.locking' => '\\OC\\Memcache\\Redis', 'redis' => array ( 'host' => 'redis', 'port' => 6379, 'dbindex' => 1, ),
-
Ich habe nun mit :
docker run -d --name redis-qnap --restart=always -p 6379:6379 -v /share/CE_CACHEDEV1_DATA/Container/redis-data:/data -v /share/CE_CACHEDEV1_DATA/Container/redis-data/conf/redis.conf:/usr/local/etc/redis/redis.conf redis redis-server /usr/local/etc/redis/redis.conf
einen redis Container als Host auf meinem QNAP installiert. Config kann bearbeitet werden und auch eine Dump.rdb wurde erzeugt.
Nun habe ich Master ( 192.168.2.xxx) im Container als Bridge und zusätzlich noch einen Raspy im gleichen Netzwerkadressraum.
Ich schaffe es aber nicht mitiobroker setup custom
Redis einzubinden. Selbst wenn ich die IP des Redis Containers angeben, kommt die Fehlermeldung.
Do you want to migrate objects and states from "jsonl/jsonl" to "redis/redis" [y/N]: y Migrating the objects database will overwrite all objects! Are you sure that this is not a slave host and you want to migrate the data? [y/N]: y Connecting to previous DB "jsonl/jsonl"... Server Configured backup period 7200000 is larger than the supported maximum of 35791 minutes. Defaulting to 120 minutes. Server Configured backup period 7200000 is larger than the supported maximum of 35791 minutes. Defaulting to 120 minutes. Creating backup ... This can take some time ... please be patient! host.iobroker 8521 states saved host.iobroker 10736 objects saved Backup created: /opt/iobroker/backups/2024_01_02-15_06_32_backupiobroker-migration.tar.gz updating conf/iobroker.json Connecting to new DB "redis/redis" (can take up to 20s) ... No connection to objects 10.0.3.2:6379[redis] New Database could not be connected. Please check your settings. No settings have been changed. restoring conf/iobroker.json No connection to states 10.0.3.2:6379[redis]
Ich weiss das ich in einem anderen Adressraum bin, aber gibt es da eine Lösung?
Oder kann ich den iobroker Master von Bridge in Host netzwerkmäßig ändern, und wie kann ich dann auf diesen zugreifen ausserhalb des Containers?Danke Bert
-
@bert-0 sagte in Redis in ioBroker - Überblick:
Ich habe nun mit :
docker run -d --name redis-qnap --restart=always -p 6379:6379 -v /share/CE_CACHEDEV1_DATA/Container/redis-data:/data -v /share/CE_CACHEDEV1_DATA/Container/redis-data/conf/redis.conf:/usr/local/etc/redis/redis.conf redis redis-server /usr/local/etc/redis/redis.conf
einen redis Container als Host auf meinem QNAP installiert.
Was meinst du mit "Host"? Host-Netzwerk kann nicht gemeint sein mit diesem run Befehl.
Nun habe ich Master ( 192.168.2.xxx) im Container als Bridge und zusätzlich noch einen Raspy im gleichen Netzwerkadressraum.
?? Du hast einem Bridge-Netzwerk den gleichen Adressraum zugewiesen wie dem physischen Netzwerk?
Ich weiss das ich in einem anderen Adressraum bin, aber gibt es da eine Lösung?
Oder kann ich den iobroker Master von Bridge in Host netzwerkmäßig ändern, und wie kann ich dann auf diesen zugreifen ausserhalb des Containers?Bitte nochmal detailliert beschreiben, wie die Adressbereiche aussehen, welcher Container mit welcher IP läuft und was der Raspi da für eine Rolle spielen soll.
-
@marc-berg sagte in Redis in ioBroker - Überblick:
Ich habe nun mit :
docker run -d --name redis-qnap --restart=always -p 6379:6379 -v /share/CE_CACHEDEV1_DATA/Container/redis-data:/data -v /share/CE_CACHEDEV1_DATA/Container/redis-data/conf/redis.conf:/usr/local/etc/redis/redis.conf redis redis-server /usr/local/etc/redis/redis.confeinen redis Container als Host auf meinem QNAP installiert.
Was meinst du mit "Host"? Host-Netzwerk kann nicht gemeint sein mit diesem run Befehl.
Hast du Recht, ist nur Standard ( NAT ) . Sorry
@marc-berg sagte in Redis in ioBroker - Überblick:
?? Du hast einem Bridge-Netzwerk den gleichen Adressraum zugewiesen wie dem physischen Netzwerk?
ja, das ist der Adressraum meiner Fritzbox und wird über die Bridge auf den virtuellen Switch des QNAPS geleitet. Grund ist, ich habe einen Raspy als Slave/Multihost und virtueller CCU und der liegt im gleichen Adressraum ( Iobroker Master : 192.168.2.30 und Slave Raspberry 192.168.2.40).
Wenn du hier einen anderen Konfigurationsvorschlag hast dann gerne. Der Redis Server liegt auf: 10.0.3.2. Der wir aber wahrscheinlich gekapselt vom Netzwerk.
Danke
-
@bert-0 sagte in Redis in ioBroker - Überblick:
ja, das ist der Adressraum meiner Fritzbox und wird über die Bridge auf den virtuellen Switch des QNAPS geleitet.
Das ist dann aber kein Bridge-Netzwerk, sondern ein MACVLAN (in Docker Sprech), auch wenn das QNAP hier nicht so nennt.
Wenn du hier einen anderen Konfigurationsvorschlag hast dann gerne. Der Redis Server liegt auf: 10.0.3.2. Der wir aber wahrscheinlich gekapselt vom Netzwerk.
Ja genau, auf diese IPs hast du (ohne Verbiegungen an den Routen) von außen keinen Zugriff. Darum gibt es ja das Portmapping, um über diese Ports des Hosts zuzugreifen. ABER von einem Container im MACVLAN darf nicht auf den Host zugegriffen werden.
Aus meiner Sicht hast du zwei Möglichkeiten
-
den Redis Container mit ins MACVLAN setzen (an den Virt. Switch 3) oder
-
der ioBroker Container zusätzlich an dein Bridge-Netzwerk (lxcbr0) anbinden
Im zweiten Fall kannst du vom ioB dann direkt auf den redis-Container zugreifen.
-
-
@marc-berg sagte in Redis in ioBroker - Überblick:
Aus meiner Sicht hast du zwei Möglichkeiten
den Redis Container mit ins MACVLAN setzen (an den Virt. Switch 3) oder
der ioBroker Container zusätzlich an dein Bridge-Netzwerk (lxcbr0) anbinden
Danke für deine Geduld. Der 1. Fall ( (an den Virt. Switch 3) ) ist aus meiner Sicht der beste.
jetzt scheitert das aber daran, wie ich das per Dockerbefehl bei Austausch mit einbinden kann. Das ist übrigens auch das gleiche problem bei meinem iobroker. Ich kann den über Docker installieren, aber muss danach manuell auf Bridge mit der gewünschten IP setzen.
@bert-0 sagte in Redis in ioBroker - Überblick:
docker run -d --name redis-qnap --restart=always -p 6379:6379 -v /share/CE_CACHEDEV1_DATA/Container/redis-data:/data -v /share/CE_CACHEDEV1_DATA/Container/redis-data/conf/redis.conf:/usr/local/etc/redis/redis.conf redis redis-server /usr/local/etc/redis/redis.conf
Hast du eine Idee, wie ich das per Docker so konfigurieren kann, dass die im gleichen Netzwerk sind?
Danke
Bert
-
Ich habe auch mal wieder redis probiert. Die CPU-Last sinkt von 9% auf 6%. Aber die Disk IO schnellt stark nach oben. Damit wird die SSD viel stärker gefordert und deren Lebensdauer sinkt. Ist das normal?
Da wo man nur einen Strich nähe 0 sieht ist jsonl im Einsatz. Die fast 3,5 M sind mit redis.Wegen der 3% CPU-Last hat es wenig Sinn redis zu verwenden - vor allem wenn die SSD so übermäßig belastet wird. Deswegen wieder auf jsonl umgestiegen. Der Wechsel geht ja schnell.
-
@bert-0 sagte in Redis in ioBroker - Überblick:
Hast du eine Idee, wie ich das per Docker so konfigurieren kann, dass die im gleichen Netzwerk sind?
Da gibt es doch so eine schicke Oberfläche in der Container Station, geht das damit nicht?
Unter Docker musst du dein run Befehl um den "network" Parameter ergänzen:
docker run --network=mein_macvlan_netzwerk --ip=192.168.2.x ....
Wie das Netzwerk heißt bekommst du mit
docker network ls
raus. Aber ich bin, was QNAP angeht, völlig ahnungslos und weiß nicht, wie das unter der Haube verdrahtet ist.
-
@dr-bakterius sagte in Redis in ioBroker - Überblick:
Ist das normal?
Das hängt im Wesentlichen davon ab, wie die DB parametriert wurde und wieviel Datenänderungen du an den States hast. Über den "save" Parameter kann man ja sehr genau vorgeben, wie oft gespeichert werden soll.
# Unless specified otherwise, by default Redis will save the DB: # * After 3600 seconds (an hour) if at least 1 change was performed # * After 300 seconds (5 minutes) if at least 100 changes were performed # * After 60 seconds if at least 10000 changes were performed # # You can set these explicitly by uncommenting the following line. # # save 3600 1 600 100 60 10000
Außerdem könnte man auch noch auf "AOF" umstellen. Damit werden alle Änderungen an den Daten immer als kleine Häppchen an die .aof Datei angehängt. In regelmäßigen Abständen (je nach Konfiguration) erfolgt dann ein Umkopieren in die *.rdb Datei. Ob dabei die Schreiblast sinkt, habe ich aber nicht ausprobiert. Ich fand' es charmant, dass die Daten praktisch in Echtzeit weggeschrieben werden, ohne dass jedesmal die rdb-Datei komplett neu erstellt wird.
-
Moin,
vor einiger Zeit hatte ich States und Objects auf Redis umgestellt. Jedesmal, wenn die VM neu starten oder einfach nur herunterfahren sollte, hat das etwa 1:40 Minuten gedauert. Heute habe ich mich mal auf die Suche gemacht, auch, weil ich die Warnung bekam, dass die Locale wieder umgestellt werden muss. Da wurde also gestern Abend bei den Updates die Config überschrieben.
Das Ergebnis der Suche war, dass ioBroker zu lange brauchte und dann abgeschossen wurde. Also mal die Logs von ioBroker angesehen und herausgefunden, dass dort schon die Verbindung zur Datenbank fehlte. Demnach wurde Redis zu früh beendet, oder ioBroker zu spät.
Also habe ich erstmal beides auf JSONL umgestellt. Nun fährt die VM wieder ruck-zuck herunter und startet dementsprechend flott neu.
Mit JSONL gibt top folgendes aus:
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND 601 iobroker 20 0 11.2g 482936 45336 S 21.6 5.9 5:59.37 iobroker.js-con 701 iobroker 20 0 11.2g 428816 46196 S 15.6 5.3 4:48.49 io.javascript.0 679 iobroker 20 0 21.1g 278612 48672 S 4.7 3.4 1:37.32 node-red 2004 iobroker 20 0 693180 107708 43808 S 4.3 1.3 1:14.40 io.statistics.0 647 iobroker 20 0 775992 136060 37920 S 4.0 1.7 1:14.89 io.influxdb.0 801 iobroker 20 0 10.7g 134092 40248 S 3.3 1.6 0:44.06 io.hue.0 2161 iobroker 20 0 886904 90892 38384 S 0.7 1.1 0:08.82 io.ws.0 916 iobroker 20 0 691744 89264 38744 S 0.3 1.1 0:03.31 io.hm-rpc.2 931 iobroker 20 0 685204 83752 39288 S 0.3 1.0 0:03.53 io.s7.0 946 iobroker 20 0 686820 81716 39624 S 0.3 1.0 0:02.20 io.chromecast.0 1701 iobroker 20 0 749024 77496 38700 S 0.3 1.0 0:04.54 io.jeelink.0 2039 iobroker 20 0 966580 109288 39884 S 0.3 1.3 0:07.40 io.web.0 2236 iobroker 20 0 883100 85336 39796 S 0.3 1.0 0:03.28 io.tankerkoenig
Die CPU Auslastung der VM hat sich etwas erhöht:
Disk IO ist ok:
RAM passt auch:
Daher lasse ich es erstmal auf JSONL. Wenn mir Probleme auffallen, werde ich eine eigene VM oder einen Container für Redis anlegen, welcher durchläuft, wenn ioBroker neu startet oder herunterfährt. Allerdings könnte da dann noch das Netzwerk reingrätschen, wenn die VM von ioBroker das Netzwerk kappt, bevor ioBroker fertig zum herunterfahren ist. - Irgendwas ist ja immer
Ach ja die Konfig der VM:
und vom Proxmox Host: (Intel NUC 12, NUC12WSHi5 Wall Street Canyon Mini-PC Desktop)
-
@peterfido ich habe keine VM, aber ich habe den Reboot oder Shutdown meines Server anders gelöst. Via Skript beende ich zunächst den ioBroker, danach speichere ich die Redis-DB zwangsweise und danach der eigentliche Shutdown oder Reboot.
Das funktioniert ohne Probleme, ohne Datenverlust und geht richtig schnell.
Ro75.