NEWS
EXPERIMENTELL: JsonL Datenbank für js-controller
-
Hi!
habe heute morgen umgestellt. Master läuft auf den ersten Blick einwandfrei. Disk I/o scheint nun in einer andern Welt zu sein.Mein Slave bekomme ich aber noch nicht ins Rennen.
Bekomme nur die Fehlermeldung dort:
No Connection to Database Possible...Current configuration: - Objects database: - Type: jsonl - Host/Unix Socket: 192.165.175.15 - Port: 9001 - States database: - Type: jsonl - Host/Unix Socket: 192.165.175.15 - Port: 9000 - Data Directory: ../../iobroker-data/
Muss ich hier noch was anpassen?
Iobroker Log des Slaves hat auch nur die Fehlermeldung drinne, verbunden mit Restarts deswegen. -
@adnim wie sieht die Master konfig aus?
-
Current configuration: - Objects database: - Type: jsonl - Host/Unix Socket: 127.0.0.1 - Port: 9001 - States database: - Type: jsonl - Host/Unix Socket: 127.0.0.1 - Port: 9000 - Data Directory: ../../iobroker-data/
-
@adnim Jupp der Master erlaubt nur lokale Verbindungen. Schreib in die konfig beim Master mal 0.0.0.0 als ip rein bei beiden dbs. Dann klappt’s auch.
-
Ja dann klappts auch Danke!
Datenbank läuft Stabil, Write Load ist komplett verschwunden super Sache.
-
@apollon77 @AlCalzone
Angeregt durchs mitlesen des Disk Write Beitrags und auch schon längeren Überlegungen ob ich mein System auf redis umstellen soll oder nicht, habe ich mich nun mal getraut auf jsonl umzustellen.Bilder sagen oft mehr als tausend Worte:
Einfach Toll wie mit euren stetigen Optimierungen und Verbesserungen die ihr anscheinend aus dem Nichts zaubert (kommt mir nicht wissenden zumindest so vor) ioBroker so weiter entwickelt wird.
Weiter so!
-
sieht ja echt interessant aus, lohnt es sich von Redis auf jsonl umzustellen??
Ich betreibe auf dem iobroker auch ein Redisserver und n Slave auf der Syno..
-
@ilovegym das musst du wissen. Am Ende kann redis genau so sparsam sein wenn man ihn richtig einrichtet ;-))
-
Danke, ok, ich wart mal ab, was die Erfahrungen in den nächsten Wochen so zeigen, und wenn ich Zeit habe, teste ich das mit nem Clone mal aus.
Denke aber, mein Redis ist schon echt flott.
Bin gerade fertig mit der Umstellung von den Xiaomi-Gateways auf n CC26X2R, und hab 140 Sensoren neu angelernt..
-
@ilovegym sagte in EXPERIMENTELL: JsonL Datenbank für js-controller:
Bin gerade fertig mit der Umstellung von den Xiaomi-Gateways auf n CC26X2R, und hab 140 Sensoren neu angelernt..
Wow 140... das Gleiche hatte ich vor ca. einem Jahr gemacht und da waren es „nur“ 50 Sensoren und das war schon eine große Arbeit
-
@apollon77 @AlCalzone
Anbei meine Erfahrungen mit jsonl, einfach nur top, super ArbeitDisk IO pro Stunden liegt jetzt bei 260MiB, statt ursprünglich 35 GiB
Weiter ist mir aufgefallen, dass die CPU Last mit jsonl ebenfalls runter gegangen ist:
-
@scrounger sagte in EXPERIMENTELL: JsonL Datenbank für js-controller:
Weiter ist mir aufgefallen, dass die CPU Last mit jsonl ebenfalls runter gegangen ist:
bei mir genau das Gegenteil
-
@crunchip sagte in EXPERIMENTELL: JsonL Datenbank für js-controller:
bei mir genau das Gegenteil
Bei mir ist die CPU-Last auch gestiegen. Jedoch nicht ganz so extrem sondern "nur" um ~65% (6,2% > 10,2%). Damit liegt sie etwas höher als zu Beginn mit file|file (9,7%).
-
Meine CPU last hat sich auch um ca.2% erhöht, dafür keinerlei Schreibload mehr. Läuft Spitze. Maybee sollte das der neue
StandartStandard werden mit JsonL!?
-
@adnim
a) Standard ist keine Standart.b) In deinem Fall sehe ich einen Anstieg wie bei mir um ~65% (von 2% auf 3,5%) oder 1,5%-Punkte.
-
@dr-bakterius
danke für den Hinweis!Ja Prozentual ist der Anstieg schon heftig. Aber da bin ich ganz entspannt das kostet mich etwas Strom, CPU hat ja keinen Verschleiß wie eine Festplatte. Wenn man das noch in den Griff bekommt umso besser, lüppt aber auch so...
-
@adnim Stimme dir eh zu - finde das neue Konzept bisher auch toll. Wobei eine CPU und die anderen Komponenten natürlich auch schneller altern je höher sie belastet werden. Doch das ist bei diesen Werten und im Vergleich zu den Datenträgern wirklich zu vernachlässigen.
-
Bei mir sieht es bzgl. der Diskwrites sehr ähnlich aus:
Nach der Einstellung geringerer Schreibzyklen für redis (States und Objects) ist die Schreiblast deutlich runtergegangen. Mit der Umstellung auf die aktuelle Version des js-controller und jsonl (erst nur Objects dann States und Objects) ist ein weiterer spürbarer Rückgang zu verzeichnen.
Die CPU-Auslastung geht - insbesondere seit auch die States in der jsonl-DB liegen - spürbar nach oben (~+40 % von 3,25% auf 4,5%).
Gruß Marco
-
@adnim sagte in EXPERIMENTELL: JsonL Datenbank für js-controller:
Maybee sollte das der neue Standard werden mit JsonL!?
Wieviele hatten denn seit ihrer Umstellung Situationen, in denen das neue Schreibverfahren seine Robustheit unter Beweis stellen konnte?
-
@lonsimbt sagte in EXPERIMENTELL: JsonL Datenbank für js-controller:
3,25% auf 4,5%
Das ist jetzt alles nicht so die Welt, aber wir haben bereits grundlegend was in der File DB identifiziert (der Teil, der auch von JSONL genutzt wird), was das verursachen könnte.