Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. Beispiel alle ioBroker Prozesse / Speicherverbrauch

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    Beispiel alle ioBroker Prozesse / Speicherverbrauch

    This topic has been deleted. Only users with topic management privileges can see it.
    • ruhr70
      ruhr70 last edited by

      Lösch das alte Widget doch bitte mal.

      Dann würde ich zum testen einmal das Beispiel-Widget importieren und dann es noch einmal an ein leeres Widget wagen.

      Das mit dem Header [0], Name [1] ist mir auch aufgefallen. Ich denke, dass ist nur ein Bezeichnungsfehler im Widget.

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

        P.S.:

        ggf. liegt es auch noch an einer Deinen CSS Einstellungen?

        Normalerweise hat das Widget andere Farben. Im Standard so, wie in meinen Screenshots.

        1 Reply Last reply Reply Quote 0
        • Homoran
          Homoran Global Moderator Administrators last edited by

          @ruhr70:

          ggf. liegt es auch noch an einer Deiner CSS Einstellungen? `
          Treffer!

          Das sind die Einstellungen für den TV-Spielfilm Adapter von pix.

          Jetzt muss ich emich auch noch in CSS reinarbeiten, wie ich das beim Fernsehprogramm hinbekomme MIT diesen Einstellungen und bei allen anderen ohne.

          Tippe mal auf "global/projekt"

          Danke

          Rainer

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

            FYI.

            Ich bin an ähnlicher Funktionalität dran.
            48_2016-05-27_21_39_04-iobroker.admin.png

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

              @Bluefox:

              FYI.

              Ich bin an ähnlicher Funktionalität dran. `

              cool!

              Warum sind die Werte dort so bescheiden?

              Nimmst Du nicht RSS? Oder gibt es Optimierungen 😉

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

                @ruhr70:

                @Bluefox:

                FYI.

                Ich bin an ähnlicher Funktionalität dran. `

                cool!

                Warum sind die Werte dort so bescheiden?

                Nimmst Du nicht RSS? Oder gibt es Optimierungen 😉 `
                Du kannst jetzt schauen, wie es bei dir aussieht 🙂 Es ist schon RSS Wert.

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

                  @Bluefox:

                  Du kannst jetzt schauen, wie es bei dir aussieht 🙂 Es ist schon RSS Wert. `

                  Ja, stimmt! Schon Wahnsinn der Bluefox… 😄

                  Allerdings hat mein Rechner gar keinen Speicher 😉

                  327_iobroker_admin_ram.jpg

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

                    Ich habe es nicht gefunden (Objekte: Admin oder Host):

                    Legst Du die Summen irgendwo in einem Datenpunkt ab?

                    • Geamtspeicherverbrauch ioBroker absolut

                    • Gesamtspeicherverbrauch prozentual

                    • Anzahl aktiver Prozesse

                    • ggf. Gesamt CPU-Last

                    Dann kann ich mein kleines Skript direkt wieder entsorgen 😉 😞

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

                      @ruhr70:

                      Ich habe es nicht gefunden (Objekte: Admin oder Host):

                      Legst Du die Summen irgendwo in einem Datenpunkt ab?

                      • Geamtspeicherverbrauch ioBroker absolut

                      • Gesamtspeicherverbrauch prozentual

                      • Anzahl aktiver Prozesse

                      • ggf. Gesamt CPU-Last `
                        Es wird momentan nur "Geamtspeicherverbrauch ioBroker absolut" und Freies RAM (ab "js-controller" 0.9.1) angezeigt (direkt im admin kalkuliert)

                      "Gesamtspeicherverbrauch prozentual" Kann ich noch kalkulieren. (genauso "Anzahl aktiver Prozesse")

                      Was CPU angeht. Sind da die Werte zuverlässig?

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

                        @Bluefox:

                        Was CPU angeht. Sind da die Werte zuverlässig? `

                        Ich fürchte nicht. CPU-Time eher. Aber da fehlt dann der Vergleich.

                        Belassen wir es beim Speicher 😉

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

                          48_2016-05-28_09_11_50-iobroker.admin.png

                          Es gibt auch so was:

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

                            @Bluefox:

                            Es gibt auch so was: `

                            Aber noch nicht in den freigegebenen Versionen oder?

                            Ich habe vorhin alles aktualisiert und habe z.B. die Changelog-Anzeige noch nicht.

                            Die Zusammenfassung unter Instanzen sieht auch noch leicht anders aus:

                            327_iobroker_admin_ram_2.jpg

                            Dann hatte ich mich gewundert, warum mein Skript zwei Prozesse mehr angezeigt hatte und bin dann die Prozesse Punkt für Punkt durchgegangen.

                            Bei mir lief io.hm-rpc.2 insgesamt dreimal :?

                            Nach einem Reboot lief der Prozess nur noch einmal und die Anzeige unter Instanzen stimmt mit dem Skript überein.

                            Ist es denkbar, dass Du eine Kontrolle einbaust, ob eine Adapterinstanz z.B. mehr als einmal gestartet ist und die Zeile dann z.B. rot dargestellt wird?

                            [EDIT]

                            ein Tippfehler in der Übersicht:

                            35 Prozesse, nicht 35 Prozessen

                            1 Reply Last reply Reply Quote 0
                            • Homoran
                              Homoran Global Moderator Administrators last edited by

                              Hallo ruhr70

                              hast du das aus github?

                              Gruß

                              Rainer

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

                                @Homoran:

                                Hallo ruhr70

                                hast du das aus github? `

                                Nein. Ganz normal über Admin/Adapter installiert.

                                1 Reply Last reply Reply Quote 0
                                • Homoran
                                  Homoran Global Moderator Administrators last edited by

                                  Seltsam, habe eben auch admin upgedatetd - habe es noch nicht.

                                  Habe allerdings Probleme mit dem fast-online, habe nur online als Repo.

                                  Admin ist jetzt 1.2.1

                                  Browsercache geleert…...

                                  EDIT: unter Instanzen! das muss einem Idioten ja auch gesagt werden.

                                  Danke

                                  Rainer

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

                                    Bzgl. der Repositories habe ich auch seltsame Phänomene.

                                    Folgende Repos habe ich eingebunden:

                                    default : conf/sources-dist.json

                                    online : https://raw.githubusercontent.com/ioBro … -dist.json

                                    fast-online : http://download.iobroker.net/sources-dist.json

                                    <u>Adapter "Solarwetter"</u>

                                    Wenn ich das Repos "default" oder "online" verwende, steht beim Adapter "Solarwetter" unter Version "Fehler". Verwende ich das Repos "fast-online", wird die Version 0.0.5 angezeigt.

                                    Adapter "ioBroker Admin"

                                    Wenn ich das Repos "online" verwende, steht beim Adapter unter Version 1.2.1 (welche ich auch installiert habe). Verwende ich das Repos "fast-online", wir die Version 1.1.1 angezeigt.

                                    Kann es sein, das die Repositories auseinanderlaufen?

                                    Solarwetter nur unter "fast-online", der Admin-Adapter in der höheren Version unter "online", usw.

                                    Oder habe ich (noch) alte oder die falschen Repositories eingebunden?

                                    Gruß,

                                    Eric

                                    1 Reply Last reply Reply Quote 0
                                    • P
                                      pix last edited by

                                      @Bluefox:

                                      FYI.

                                      Ich bin an ähnlicher Funktionalität dran. Das ist dann doch einfacher, als den "ps"-Befehl auf OS X umzubauen.```ps -A -o pid,psr,pcpu,args | grep " [i]o.*";`geht schon, nur muss ich das Ergebnis natürlich wieder neu aus dem Array fischen...

                                      Pix[/i]

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

                                        @pix:

                                        @Bluefox:

                                        FYI.

                                        Ich bin an ähnlicher Funktionalität dran. Das ist dann doch einfacher, als den "ps"-Befehl auf OS X umzubauen.```ps -A -o pid,psr,pcpu,args | grep " [i]o.*";`geht schon, nur muss ich das Ergebnis natürlich wieder neu aus dem Array fischen...

                                        Pix

                                        Mit
                                        ~~[code]~~ps aux | grep " [i]o.*";
                                        sollte es auch direkt auf dem Mac funktionieren.

                                        [EDIT]

                                        Bei der Abfrage unter Linux wird von oben nach unten nach dem größten Speicherverbrauch sortiert. Für das Skript nciht relevant. Da habe ich jetzt nicht nachgesehen, ob der Parameter auch auf dem Mac zu verwenden ist.

                                        [/EDIT]

                                        Nachdem Bluefox den größten Teil in ioBroker eingebaut hat, stellt sich natürlich noch die Frage, ob es noch Sinn macht.

                                        Mir hat das Skript allerdings schon geholfen. Ich hatte beim Erstellen festgestellt, dass die hm-rpc Instanz dreimal gestartet war. Ich habe das Skript noch um einen Datenpunkt erweitert, der Anzeigt, ob alle Instanzen nur einmal aktiv sind.[/i][/code][/i]
                                        ``` `

                                        1 Reply Last reply Reply Quote 0
                                        • Homoran
                                          Homoran Global Moderator Administrators last edited by

                                          @pix:

                                          Nachdem Bluefox den größten Teil in ioBroker eingebaut hat, stellt sich natürlich noch die Frage, ob es noch Sinn macht. `
                                          Ich habe die Datenpunkte dazu noch nicht gefunden.

                                          Das Skript kann ich in vis darstellen, für Bluefox' Lösung muss ich den admin öffnen.

                                          Gruß

                                          Rainer

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

                                            @Homoran:

                                            @pix:

                                            Nachdem Bluefox den größten Teil in ioBroker eingebaut hat, stellt sich natürlich noch die Frage, ob es noch Sinn macht. `
                                            Ich habe die Datenpunkte dazu noch nicht gefunden.

                                            Das Skript kann ich in vis darstellen, für Bluefox' Lösung muss ich den admin öffnen.

                                            Gruß

                                            Rainer `

                                            Dann anbei die aktuellste Version mit der Überprüfung, ob jede Instanz nur einmal läuft:

                                            ! ```
                                            `var pfad = "Systeminfos.ioBroker.Prozesse" + "."; // Pfad in dem die Datenpunkte angelegt werden
                                            ! // Datenpunktnamen:
                                            var idProzesse = pfad + 'ioBroker_Prozesse';
                                            var idMemAll = pfad + 'ioBroker_Speicher_gesamt';
                                            var idAnzProzesse = pfad + 'ioBroker_Anzahl_Prozesse';
                                            var idCpuAll = pfad + 'ioBroker_CPU_Gesamt';
                                            var idMemPercent = pfad + 'ioBroker_Speicher_prozentual';
                                            var idInstanzenEinmal = pfad + 'ioBroker_Instanzen_einmal_aktiv';
                                            ! // regelmässige Wiederholungen der Abfrage
                                            var cronStr = "*/2 * * * ";
                                            ! var abfrage = 'ps -A aux --sort -pmem | grep " [i]o.
                                            "';
                                            ! // -----------------------------------------------------------------------------
                                            ! createState(idProzesse, "", {
                                            name: 'ioBroker laufende Prozesse Objekt',
                                            desc: 'ioBroker laufende Prozesse Objekt, Speicherverbrauch',
                                            type: 'string',
                                            unit: '',
                                            role: 'object'
                                            });
                                            ! createState(idMemAll, 0, {
                                            name: 'ioBroker Speicherverbrauch gesamt',
                                            desc: 'ioBroker Speicherverbrauch gesamt (RSS)',
                                            type: 'number',
                                            unit: 'MB',
                                            role: 'value'
                                            });
                                            ! createState(idAnzProzesse, 0, {
                                            name: 'ioBroker Anzahl Prozesse',
                                            desc: 'ioBroker Anzahl aktiver Prozesse',
                                            type: 'number',
                                            unit: '',
                                            role: 'value'
                                            });
                                            ! createState(idCpuAll, 0.0, {
                                            name: 'ioBroker CPU-Last gesamt',
                                            desc: 'ioBroker CPU-Last gesamt',
                                            type: 'number',
                                            unit: '%',
                                            role: 'value'
                                            });
                                            ! createState(idMemPercent, 0.0, {
                                            name: 'Speicherverbrauch prozentual',
                                            desc: 'Speicherverbrauch prozentual',
                                            type: 'number',
                                            unit: '%',
                                            role: 'value'
                                            });
                                            ! createState(idInstanzenEinmal, true, {
                                            name: 'keine Instanzen doppelt aktiv',
                                            desc: 'jeder aktive ioBroker Prozess ist nur einmal aktiv',
                                            type: 'boolean',
                                            unit: '',
                                            role: 'value'
                                            });
                                            ! // -----------------------------------------------------------------------------
                                            ! function doppelteProzesse(arr) {
                                            var mehrfacheProzesse = [];
                                            var anzProzesse = (arr.length);
                                            var anzProzessAktiv = 0;
                                            for (var i = 0; i < anzProzesse; i++) {
                                            if (mehrfacheProzesse.indexOf(arr[i].command) == -1) {
                                            anzProzessAktiv = zaehleProzesse(arr,arr[i].command);
                                            if (anzProzessAktiv > 1) {
                                            log("Prozess: " + arr[i].command+", mehrfach aktiv: " + anzProzessAktiv +" mal","warn");
                                            mehrfacheProzesse.push(arr[i].command);
                                            mehrfacheProzesse.push(anzProzessAktiv);
                                            }
                                            }
                                            }
                                            return mehrfacheProzesse;
                                            }
                                            ! function zaehleProzesse(arr,command) {
                                            var count = 0;
                                            var anzProzesse = (arr.length);
                                            for (var i = 0; i < anzProzesse; i++) {
                                            if(arr[i].command === command) {
                                            count++;
                                            }
                                            }
                                            return count;
                                            }
                                            ! function writeJson(json) {
                                            return JSON.stringify(json); // JSON in String umwandeln, damit das JSON in einem Datenpunkt geschrieben werden kann
                                            }
                                            ! function getMemAbsolut(json) {
                                            var anzProzesse = (json.length);
                                            var mem = 0;
                                            for (var i = 0; i < anzProzesse; i++) {
                                            mem = mem + json[i].rss;
                                            }
                                            return mem;
                                            }

                                            function getCpu(json) {
                                            var anzProzesse = (json.length);
                                            var cpu = 0.0;
                                            for (var i = 0; i < anzProzesse; i++) {
                                            cpu = cpu + json[i].cpu;
                                            }
                                            return cpu;
                                            }

                                            ! function getMem(json) {
                                            var anzProzesse = (json.length);
                                            var mem = 0.0;
                                            for (var i = 0; i < anzProzesse; i++) {
                                            mem = mem + json[i].mem;
                                            }
                                            return mem;
                                            }
                                            ! function createArrayJson(arr) {
                                            var jsonArr = [];
                                            var anzDP = 11; // Anzahl Datenreihen in der Abfrage
                                            var anzProzesse = (arr.length-1)/anzDP;
                                            ! for (var i = 0; i < anzProzesse; i++) {
                                            jsonArr.push({
                                            command: arr[10 + ianzDP], // ioBroker Prozess (COMMAND = Kommando, mit dem der Prozess gestartet wurde)
                                            pid: arr[ 1 + i
                                            anzDP], // Prozess ID
                                            cpu: parseFloat(arr[ 2 + ianzDP]), // aktueller CPU-Last in %
                                            mem: parseFloat(arr[ 3 + i
                                            anzDP]), // aktueller Verbrauch physikalischer Speicher %
                                            vmem: parseInt(arr[ 4 + ianzDP]), //
                                            rss: parseInt(arr[ 5 + i
                                            anzDP]), // physikalische Speichernutzung
                                            start: arr[ 8 + ianzDP], // Startzeitpunkt des Prozesses
                                            time: arr[ 9 + i
                                            anzDP] // bisher verbrauchte CPU Zeit
                                            });
                                            }
                                            return jsonArr;
                                            }
                                            ! function abfrageConsole() {
                                            exec(abfrage, function(err, stdout, stderr) {
                                            if (err) {
                                            log(err,"error");
                                            return;
                                            }
                                            stdout = stdout.replace(/\n+/g, " "); // neue Zeile gegen Leerzeichen ersetzen
                                            stdout = stdout.split(/ +/g); // array erstellen, Lerzeichen als Trenner

                                                var anzProzesse = (stdout.length-1) / 11;
                                            
                                                //log(stdout);
                                                //log("Anzahl laufender ioBroker Prozesse: " + anzProzesse);
                                            
                                                var jsonArr = createArrayJson(stdout);
                                                var mem         = Math.floor(getMemAbsolut(jsonArr)/1024);
                                                var cpu         = Math.floor(getCpu(jsonArr)*10)/10;
                                                var memPercent  = Math.floor(getMem(jsonArr)*10)/10;
                                            

                                            ! var doppeltArr = doppelteProzesse(jsonArr);

                                                if(doppeltArr.length === 0) {
                                                    setState(idInstanzenEinmal,true);
                                                } else {
                                                    setState(idInstanzenEinmal,false);
                                                }
                                            

                                            ! setState(idProzesse ,writeJson(jsonArr));
                                            setState(idMemAll ,mem);
                                            setState(idAnzProzesse ,anzProzesse);
                                            setState(idCpuAll ,cpu);
                                            setState(idMemPercent ,memPercent);
                                            });
                                            }
                                            ! function abfragen() {
                                            abfrageConsole();
                                            }
                                            ! // regelmässige Wiederholungen
                                            // -----------------------------------------------------------------------------
                                            schedule(cronStr, abfragen);
                                            ! // main
                                            // -----------------------------------------------------------------------------
                                            function main() {
                                            abfragen();
                                            }
                                            ! // Start Skript:
                                            // -----------------------------------------------------------------------------
                                            ! setTimeout(main, 500);` [/i][/i][/i][/i][/i][/i][/i][/i][/i]

                                            1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            452
                                            Online

                                            31.9k
                                            Users

                                            80.2k
                                            Topics

                                            1.3m
                                            Posts

                                            14
                                            60
                                            6728
                                            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