Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. ioBroker Allgemein
    4. SQL-Adapter verursacht hohe CPU-Last

    NEWS

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    SQL-Adapter verursacht hohe CPU-Last

    This topic has been deleted. Only users with topic management privileges can see it.
    • B
      bvol @Urs last edited by bvol

      @Urs Bei mir waren string datensätze in der ts_number tabelle. Betroffene Adapter: weatherunderground, coronavirus-statistics, netatmo usw., also eigentlich alle adapter, die strings liefern. Die hm-* adapter waren nicht betroffen, da die keine strings liefern.
      Wirklich Ruhe ist bei mir erst eingekehrt, nachdem ich konsequent alle string Lieferanten vom logging excluded habe. Zudem waren haufenweise Dubletten in der DB, was man recht schnell mit einer Kopie der Tabellen via sql sehen kann. So hatte die ts_number Tabelle, die zuvor 12Mio Datensätze hatte, nach der Kopie nur noch 8 Mio Datensätze...

      Ich habe den Ärger nun auch genutzt und die Tabellen via php Script entrümpelt und alle Datensätze mit sort by id asc, ts asc eingelesen und dann, wenn val und id gleich waren, Zeile für Zeile geprüft und nur die nicht gleichen Datensätze in eine neue Tabelle geschrieben. Jetzt hat z.B. die ts_number nur noch 1.2 Mio Datensätze. Man sollte auf dem SQL Adapter einfach nie „trotzdem gleiche Werte aufzeichnen (Sekunden)“ aktivieren....

      Die String Werte (weatherunderground) lese ich jetzt via simple-api aus und schreibe sie dann auch via simple-api in die richtige Tabelle. Das Ganze via php und halt nur für die Werte, die ich sowieso nur von Zeit zu Zeit pullen will.

      Meine sql.0 Instanz konsumiert nun nur noch 0.3% mit Peaks bis 1% CPU im Docker Container, zuvor waren es dauerhaft 90-100%!

      Gleiches habe ich auch auf einer zweiten, durch mich betreuten Installation durchgeführt, mit gleichem Ergebnis. Hierbei bin ich aber über ein MySQL Performance Thema gestolpert: Ich nutze ein Synology DS 918+ mit NVME cache, dort schluckte die MariaDB die sql inserts fast in Echtzeit (ca. 1Mio records pro Minute), auf der zweiten Installation auf einer DS 216+II war das Disksystem sofort am Anschlag und ich konnte nur knapp 10'000 records pro Minute schreiben.

      1 Reply Last reply Reply Quote 0
      • U
        Urs last edited by

        @bvol Danke für die Ausführungen.

        Strings in der ts_number wären mir aufgefallen, hatte ich nie. Ich bin aber auch nicht so Fan von Strings. Ausser ein paar good, average und bad gibt es noch up down und stable, wobei ich die letzten 3 auch noch rausschmeissen werde, kann man ja anhand der Daten bei Bedarf sehen/errechnen. Am Anfang hatte ich gerade bei Netatmo auch die min/max Datum in die SQL geschrieben, aber auch das ist eigentlich Sinnfrei da ja jeder Datensatz mit der Unix-Zeit gespeichert wird.

        Danke für den Tip mit dem Kopieren. Da scheint wirklich was faul zu sein:
        52a3664d-12b0-40bd-8d00-ef87807a635f-image.png
        Entrümpeln wäre daher sicher gut...aber spätestens bei php Script muss ich da aussteigen. Gibt es da echt auch eine einfache Lösung für Nicht-Admin und Nicht-Programmierer -sprich Laien- wie mich? Oder eine Schritt-für-Schritt-so-entrümpele-ich-meine-SQL-Datenbank-auch-ohne-Doktortitel-Anleitung? 😉

        Performance Thema: Hmm, da hab ich heute auch was erlebt. Wollte Die SQL-Datenbank über HeidiSQL von Hand sichern, und zwar nicht wie sonst auf dem Windows PC sondern direkt auf einem Netzlaufwerk. Das dauerte 1h 20 Minuten für ungefähr 120Mb! Wenn ich auf dem PC sichere dann dauert es etwa 45 Sekunden. Hinter dem Netzlaufwerk verbirgt sich eine USB3 HDD welche an der Fritzbox per SMB freigegeben ist. Da erwarte ich keine Performance-Wunder aber das heute war dann doch eher sehr enttäuschend, zumal das hin und herschieben von Dateien auf dem Netzlaufwerk -in Anbetracht der eingesetzten Hardware - eine durchaus akzeptable Performance liefert. Muss kein SQL-Problem wie bei dir sein, kann genau so gut auch an meiner Unkenntnis liegen und ich hab irgendwo einen Schrott konfiguriert...

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

          @bvol sagte in SQL-Adapter verursacht hohe CPU-Last:

          Meine Vermutung ist nun, dass sql 1.13.1 irgendein Quatsch mit der DB anstellt

          Mal Frech gefragt ... über Admin könnt Ihr ja auf frühere Versionen zurück ... Könntet Ihr mal schauen ob Ihr die Version findet wo das losgeht? Also - ist es wirklich die 1.13.1? Dann schaue ich da mal rein

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

            Wie viele States habt Ihr so aktiviert?

            Wer "Lust" hat mal was auszuprobieren: https://github.com/ioBroker/ioBroker.sql/issues/127#issuecomment-647346141

            Farmer-cb created this issue in ioBroker/ioBroker.sql

            closed sql-adapter verursacht hohe CPU-Auslastung #127

            1 Reply Last reply Reply Quote 0
            • U
              Urs last edited by

              Ich schreibe ungefähr 150 States aus ca 30 Adaptern in die DB. Waren aber auch schon bis 190 und als ich die Probleme hatte waren es ungefähr 160.

              Die Versionen zurück oder Dein Link hatte ich noch nicht den Mut und die Zeit es auszuprobieren, da es im Moment bei mir läuft (ohne die beiden Internet-Speedtest-Adapter wie oben beschrieben).

              1 Reply Last reply Reply Quote 0
              • s.bormann
                s.bormann Most Active last edited by

                Hallo,

                ich habe vor einigen Tagen auch alle Werte auf Typ "Nummer" umgestellt. Seither habe ich keine Probleme mit der Prozessorlast mehr. Irgendwas beim Speichern von anderen Datentypen scheint problematisch zu sein!

                LG

                apollon77 1 Reply Last reply Reply Quote 0
                • apollon77
                  apollon77 @s.bormann last edited by

                  @s-bormann Das mag sein ... der Fix den wir gemacht haben kann sehr gut damit zu tun haben ... wenn nämlich datentypen nicht definiert waren kam es vor das danach dinge mehrfach ausgeführt wurden und sowas ...

                  1 Reply Last reply Reply Quote 0
                  • Z
                    Zappie last edited by

                    Screenshot_2020-06-27 pve - Proxmox Virtual Environment.png

                    Hallo,

                    Für mich ist das Upgrade auf Version 1.14.2 die Lösung.

                    Gruss

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

                      @Zappie Danke die Antwort habe ich gebraucht 🙂

                      s.bormann 1 Reply Last reply Reply Quote 0
                      • B
                        bvol last edited by

                        1.14.2 verhält sich unauffällig. CPU Last im erwarteten Bereich, also gem. top zwischen 0 und 0.4%. Wie es sein soll.

                        1 Reply Last reply Reply Quote 0
                        • B
                          bvol @Urs last edited by bvol

                          @Urs hier das Cleanup Script: (es legt eine zusätzliche Tabelle mit den "gesäuberten" Daten an. Es sortiert nach ID und TS und schreibt nur die zum vorigen Wert geänderten Werte.)

                          <?php
                          
                          // SQL Verbindung
                          			$sqlserver = "MYSQLSERVERIP:3307"; // DB Server:Port
                          			$sqluser = "admin"; // DB User
                          			$sqlpw = "*******"; // DB User PW
                          			$sqlDB = "iobroker"; // DB Name
                          			$sourceTable = "ts_number"; // Source Table
                          			$cleanTable = $sourceTable ."_cleaned"; // Temp Table
                          			$writedatasets =100; // Number of datasets written to Temp Table using single SQL Statement
                          			$SQLqueryLIMIT=0; // For Testing purposes. 0 selects all Source sets.
                          
                          
                          // DB Verbindung bauen
                          			error_reporting(0);
                          			$db = mysqli_connect($sqlserver, $sqluser, $sqlpw, $sqlDB);
                          			print_r ($db->connect_error);
                          			if ($db->connect_errno) {
                          			    die('Sorry - gerade gibt es ein Problem');
                          			}
                          // Attempt select query execution
                          if ($SQLqueryLIMIT > 0) {
                          	$sql = "SELECT * FROM ".$sourceTable." ORDER BY id ASC,ts ASC LIMIT ".$SQLqueryLIMIT;
                          }
                          else {
                          	$sql = "SELECT * FROM ".$sourceTable." ORDER BY id ASC,ts ASC";
                          }
                          
                          
                          // load Table to memory
                          if($result = mysqli_query($GLOBALS['db'],$sql)){
                          // do nothing
                          }
                          
                          // Create Cleantable
                          
                          $sql ="DROP TABLE IF EXISTS `".$cleanTable."`";
                          mysqli_query($GLOBALS['db'],$sql);
                          $sql ="CREATE TABLE `".$cleanTable."` SELECT * FROM `".$sourceTable."` WHERE 1 = 2";
                          mysqli_query($GLOBALS['db'],$sql);
                          $sql ="ALTER TABLE `".$cleanTable."` ADD PRIMARY KEY (`id`,`ts`)";
                          mysqli_query($GLOBALS['db'],$sql);
                          
                          
                          $idprev=0;
                          $valprev=0;
                          $saetze=0;
                          $DataArr = array();
                          while($row = mysqli_fetch_array($result)){
                          	if (($row['val']==$valprev) && ($row['id']==$idprev)) {
                          		//echo $idprev .  " " . $valprev .  " " . $tsprev  . " Behalten \n";
                          		//echo $row['id'] .  " " . $row['val'] .  " " . $row['ts']  . " Loeschen \n";
                          		}
                          	else
                          		{
                          			$fieldVal1 = ($row['id']);
                                $fieldVal2 = ($row['ts']);
                                $fieldVal3 = ($row['val']);
                          			$fieldVal4 = ($row['ack']);
                          			$fieldVal5 = ($row['_from']);
                          			$fieldVal6 = ($row['q']);
                          			$DataArr[] = "('$fieldVal1','$fieldVal2','$fieldVal3','$fieldVal4','$fieldVal5','$fieldVal6')";
                          			$idprev=$row['id'];
                          			$valprev=$row['val'];
                          			$tsprev=$row['ts'];
                          			$saetze++;
                          		}
                          	if ($saetze==$GLOBALS['writedatasets']){
                          		$sql = "INSERT INTO ".$cleanTable." (id, ts, val, ack, _from, q) values ";
                          		$sql .= implode(',', $DataArr);
                          		$sql .= ";";
                          		// echo $sql;
                          		mysqli_query($GLOBALS['db'], $sql);
                          		$saetze=0;
                          		unset($DataArr); // $DataArr is gone
                          		$DataArr = array(); // $DataArr is here again
                          	}
                          
                          
                          }
                          if ($saetze>=0){
                          	//echo implode(',', $DataArr);
                          	$sql = "INSERT INTO ".$cleanTable." (id, ts, val, ack, _from, q) values ";
                          	$sql .= implode(',', $DataArr);
                          	$sql .= ";";
                          	//echo $sql;
                          	mysqli_query($GLOBALS['db'], $sql);
                          }
                          
                          echo mysqli_num_rows($result);
                          // Free result set
                          mysqli_free_result($result);
                          // DB Verbindung schliessen
                          mysqli_close($db);
                          ?>
                          
                          

                          Code als php Script speichern und mit php ausführen. ACHTUNG: Script zieht die gesamte Tabelle in den Speicher, sorgt also für genügend RAM, je nachdem wie gross die Tabelle ist.

                          Zum Testen $SQLqueryLIMIT mal auf 1000 setzen, dann werden nur die ersten 1000 Tabelleneinträge geholt.

                          $writedatasets =100; definiert die Anzahl an Datensätzen, die mittels einem SQL Statement in die cleaned Tabelle geschrieben werden. Sorgt für mehr Speed, kann aber den MySQL Server überfordern. Mit dem Wert 100 habe ich gute Erfahrungen gemacht.

                          $sourceTable = "ts_number"; -> gibt die zu lesende Tabelle an.

                          Wenn das Ergebnis den Erwartungen entspricht, dann mittels phpMyAdmin o.Ä. die Tabellen entsprechend umbenennen...

                          U 1 Reply Last reply Reply Quote 0
                          • s.bormann
                            s.bormann Most Active @apollon77 last edited by

                            @apollon77 Bei mir läuft auch wieder alles! Danke fürs Fixen!

                            1 Reply Last reply Reply Quote 0
                            • U
                              Urs @bvol last edited by

                              @bvol hey, cool, vielen Dank. Muss mal schauen wann ich dazu komme das mal auszuprobieren. Melde mich wieder.

                              1 Reply Last reply Reply Quote 0
                              • etv
                                etv @Urs last edited by

                                Ich habe die selben Meldungen für Datenpunkte die ich leider gelöscht habe bevor ich das Logging disabled hab...

                                Aber durch die ganze Testerei hab ich jetzt verschiedene hässliche Meldungen vom SQL Adapter bzw von MariaDB:

                                sql.0	2020-06-04 03:59:59.727	warn	(3939) No realID found for web-speedy.0.Results.server.ping
                                sql.0	2020-06-04 03:59:59.727	warn	(3939) No realID found for web-speedy.0.Results.speeds.upload_MB
                                sql.0	2020-06-04 03:59:59.727	warn	(3939) No realID found for web-speedy.0.Results.speeds.download_Mb
                                sql.0	2020-06-04 03:59:59.727	warn	(3939) No realID found for web-speedy.0.Results.speeds.download_MB
                                sql.0	2020-06-04 03:59:59.727	warn	(3939) No realID found for vodafone-speedtest.0.Results.ping.packetLoss
                                sql.0	2020-06-04 03:59:59.727	warn	(3939) No realID found for vodafone-speedtest.0.Results.ping.avg
                                sql.0	2020-06-04 03:59:59.727	warn	(3939) No realID found for vodafone-speedtest.0.Results.ping.max
                                sql.0	2020-06-04 03:59:59.727	warn	(3939) No realID found for vodafone-speedtest.0.Results.ping.min
                                sql.0	2020-06-04 03:59:59.727	warn	(3939) No realID found for vodafone-speedtest.0.Results.upload_Mb
                                sql.0	2020-06-04 03:59:59.727	warn	(3939) No realID found for vodafone-speedtest.0.Results.upload_MB
                                sql.0	2020-06-04 03:59:59.727	warn	(3939) No realID found for vodafone-speedtest.0.Results.download_MB
                                

                                Auch meine Frage - wie bekommt man die weg? Wie kann man das SQL Logging für nicht mehr existente Datenpunkte abdrehen?

                                Liebe Grüße
                                Tom

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

                                  @etv Geloggt wird eh nicht mehr, aber die Werte befinden sich noch in der Datenbank. Das wäre auch so, wenn du das Logging vorher deaktiviert hättest. Ich habe die entsprechenden Werte direkt aus der Datenbank gelöscht. Da sollte man aber wissen was man tut.

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

                                    @Dr-Bakterius Dem Adapter ist egal was in der DB steht ... kann es sein das aus irgend einem Grund nur der STate gelköscht ist aber das Objekt noch da ist ... ja das Thema steht noch auf der Liste ...

                                    @etv
                                    mach bitte mal an der Kommandozeile

                                    iobroker object get vodafone-speedtest.0.Results.ping.packetLoss

                                    und

                                    iobroker state get vodafone-speedtest.0.Results.ping.packetLoss

                                    Und sag mal was das gibt

                                    liv-in-sky Dr. Bakterius etv 3 Replies Last reply Reply Quote 0
                                    • liv-in-sky
                                      liv-in-sky @apollon77 last edited by

                                      @apollon77

                                      habe da auch massig davon

                                      Image 6.png

                                      kam durch json-import von anderen usen - für script-testen
                                      datenpunkte sind mitlerweile gelöscht

                                      apollon77 1 Reply Last reply Reply Quote 0
                                      • apollon77
                                        apollon77 @liv-in-sky last edited by

                                        @liv-in-sky Und das State? das noch da?

                                        liv-in-sky 1 Reply Last reply Reply Quote 0
                                        • liv-in-sky
                                          liv-in-sky @apollon77 last edited by

                                          @apollon77

                                          der wird doch mitgelöscht, wenn man die datenpunkte löscht ? oder

                                          habe mal abgefragt:

                                          log(getState('maxcube.0.devices.thermostat_101881.setpoint').val)
                                          

                                          Image 11.png

                                          apollon77 1 Reply Last reply Reply Quote 0
                                          • apollon77
                                            apollon77 @liv-in-sky last edited by

                                            @liv-in-sky Ja sollte er ... ich versuche es zu verstehen ... 🙂 Also alles ausschliessen

                                            An sich liesst der sql Adapter zu Beginn die Objekte die ein custom haben ... also wenn Objekte gelöscht sind sollte er die nie bekommen

                                            liv-in-sky 2 Replies Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate
                                            FAQ Cloud / IOT
                                            HowTo: Node.js-Update
                                            HowTo: Backup/Restore
                                            Downloads
                                            BLOG

                                            862
                                            Online

                                            31.6k
                                            Users

                                            79.6k
                                            Topics

                                            1.3m
                                            Posts

                                            sql adapter cpu last
                                            13
                                            79
                                            6833
                                            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