Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Tester
    4. EXPERIMENTELL: JsonL Datenbank für js-controller

    NEWS

    • Monatsrückblick - April 2025

    • Minor js-controller 7.0.7 Update in latest repo

    • Save The Date: ioBroker@Smart Living Forum Solingen, 14.06.

    EXPERIMENTELL: JsonL Datenbank für js-controller

    This topic has been deleted. Only users with topic management privileges can see it.
    • Dr. Bakterius
      Dr. Bakterius Most Active @apollon77 last edited by Dr. Bakterius

      @apollon77 Ich habe mal auf 20 Sekunden gestellt - dauert aber geht. Dann 5 Sekunden - geht auch. Und danach wieder auf 2 Sekunden. Geht jetzt plötzlich auch wieder. Dauert aber länger als gewöhnlich (wenn der Broker läuft geht es sofort). Der Host läuft auf Sparflamme und hat nicht viel zu tun. Was soll ich sagen...

      Bleibt noch das Thema mit der nicht komprimierten objects.jsonl.

      apollon77 1 Reply Last reply Reply Quote 0
      • apollon77
        apollon77 @Dr. Bakterius last edited by

        @dr-bakterius Naja ok das es wenn iobroker nicht läuft kurz dauert (und bissl länger also bei controller 3.1.x) ist normal.

        Wenn kein iobroker läuft dann ist die DB nicht da, also startet der CLI Kommando erstmal eine DB damit er dahin verbinden kann. Das sind halt die paar Sekunden. Und das muss er nicht wenns schon läuft - dann ists ja schon am laufen.

        Dr. Bakterius 1 Reply Last reply Reply Quote 0
        • Dr. Bakterius
          Dr. Bakterius Most Active @apollon77 last edited by

          @apollon77 Okay, alles klar. Vielleicht dauert es jetzt länger weil die Datenbank größer ist? Mit zwei Sekunden hat es doch nicht geklappt (hatte zu speichern vergessen), aber mit drei Sekunden geht es jetzt.

          apollon77 1 Reply Last reply Reply Quote 0
          • apollon77
            apollon77 @Dr. Bakterius last edited by

            @dr-bakterius Wenn das einlesen einer jsonl DB wegen dem gewählten Ansatz länger dauert als das lesen und parten eines reinen JSOns (was gut sein kann), dann könnte da was dran sein.
            @AlCalzone

            1 Reply Last reply Reply Quote 0
            • AlCalzone
              AlCalzone Developer @Dr. Bakterius last edited by AlCalzone

              @dr-bakterius sagte in EXPERIMENTELL: JsonL Datenbank für js-controller:

              Hieß es nicht doppelte Größe und 1.000 Zeilen? Es hat die dreifache Größe und über 10.000 Zeilen mehr!

              Mit doppelte Größe war die Anzahl der Zeilen gemeint. @apollon77 hat das schon richtig wieder gegeben.

              Komprimiert wird, wenn die Anzahl der Zeilen (d.h. Schreib- und Löschoperationen) in der Datei doppelt so hoch ist wie nötig und nur dann wenn diese Anzahl mindestens 1000 beträgt.
              Es wäre also tatsächlich nach weiteren 287 Updates passiert. An den Zahlen können wir durchaus noch schrauben - das war ein erster Wurf.

              Und ja, es kann sein, dass das Starten länger dauert, weil mehr geparsed wird. Ich hab ne Idee wie man das optimieren könnte. Kannst du deine (recht große) Objects DB teilen (auch gerne privat per E-Mail) oder stehen da zu viele Geheimnisse drin?

              Dr. Bakterius 1 Reply Last reply Reply Quote 0
              • Dr. Bakterius
                Dr. Bakterius Most Active @AlCalzone last edited by

                @alcalzone Okay, danke für die Erklärung. Dann habe ich dich beim ersten Mal falsch verstanden. Alles gut. Nachdem das ganze noch experimentell ist, vermutet man hinter jeder Sache gleich einen Bug. 😊

                Ich denke, mit 10.700 Objekten bin ich eher im Durchschnitt.

                1 Reply Last reply Reply Quote 0
                • A
                  Adnim last edited by

                  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.

                  apollon77 1 Reply Last reply Reply Quote 0
                  • apollon77
                    apollon77 @Adnim last edited by

                    @adnim wie sieht die Master konfig aus?

                    A 1 Reply Last reply Reply Quote 0
                    • A
                      Adnim @apollon77 last edited by

                      @apollon77

                      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/
                      
                      
                      apollon77 1 Reply Last reply Reply Quote 0
                      • apollon77
                        apollon77 @Adnim last edited by

                        @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.

                        A Neuschwansteini 2 Replies Last reply Reply Quote 0
                        • A
                          Adnim @apollon77 last edited by Adnim

                          @apollon77

                          Ja dann klappts auch 🙂 Danke!

                          Datenbank läuft Stabil, Write Load ist komplett verschwunden super Sache.

                          1 Reply Last reply Reply Quote 0
                          • FredF
                            FredF Most Active Forum Testing last edited by

                            @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:


                            Diskwrites.PNG


                            DiskwritesJSONI.PNG

                            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!

                            1 Reply Last reply Reply Quote 2
                            • Neuschwansteini
                              Neuschwansteini @apollon77 last edited by

                              @apollon77

                              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..

                              apollon77 1 Reply Last reply Reply Quote 0
                              • apollon77
                                apollon77 @Neuschwansteini last edited by

                                @ilovegym das musst du wissen. Am Ende kann redis genau so sparsam sein wenn man ihn richtig einrichtet ;-))

                                Neuschwansteini 1 Reply Last reply Reply Quote 0
                                • Neuschwansteini
                                  Neuschwansteini @apollon77 last edited by

                                  @apollon77

                                  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.. 😄

                                  S 1 Reply Last reply Reply Quote 1
                                  • S
                                    saeft_2003 Most Active @Neuschwansteini last edited by

                                    @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 🙈

                                    1 Reply Last reply Reply Quote 0
                                    • Scrounger
                                      Scrounger Developer last edited by

                                      @apollon77 @AlCalzone
                                      Anbei meine Erfahrungen mit jsonl, einfach nur top, super Arbeit 👍

                                      9dcde5ce-51f8-4d16-8c1f-3c674d9e18af-grafik.png

                                      Disk 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:
                                      eec939b6-59c0-4fa7-897e-fa692d9790c0-grafik.png

                                      crunchip L 2 Replies Last reply Reply Quote 3
                                      • crunchip
                                        crunchip Forum Testing Most Active @Scrounger last edited by

                                        @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
                                        77dcfd91-2071-4051-aa78-fa99f79a4d2a-image.png

                                        Dr. Bakterius 1 Reply Last reply Reply Quote 0
                                        • Dr. Bakterius
                                          Dr. Bakterius Most Active @crunchip last edited by Dr. Bakterius

                                          @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%).

                                          1 Reply Last reply Reply Quote 0
                                          • A
                                            Adnim last edited by Adnim

                                            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!?

                                            cpu.JPG
                                            jsonl.JPG

                                            Dr. Bakterius O 2 Replies Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            926
                                            Online

                                            31.6k
                                            Users

                                            79.4k
                                            Topics

                                            1.3m
                                            Posts

                                            20
                                            187
                                            16451
                                            Loading More Posts
                                            • Oldest to Newest
                                            • Newest to Oldest
                                            • Most Votes
                                            Reply
                                            • Reply as topic
                                            Log in to reply
                                            Community
                                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                            The ioBroker Community 2014-2023
                                            logo