Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. ioBroker Allgemein
  4. [gelöst] Leistungswerte der Hardware auslesen und anzeigen

NEWS

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    15
    1
    824

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    13
    1
    680

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    1.9k

[gelöst] Leistungswerte der Hardware auslesen und anzeigen

Geplant Angeheftet Gesperrt Verschoben ioBroker Allgemein
90 Beiträge 13 Kommentatoren 23.2k Aufrufe
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • ruhr70R Offline
    ruhr70R Offline
    ruhr70
    schrieb am zuletzt editiert von
    #3

    Bei mir läuft das Hauptsystem auf einer VM (esxi) unter Ubuntu.

    Ich frage per Skript die Zustände ab und schreibe sie in Datenpunkten:

    uptime und Load 1,5,15:

    ! // ermittelt auf Linuxrechner die Uptime und die Systemauslastung // mit dem Linux Befehl: uptime // // Beduetung der Werte: // http://www.selflinux.org/selflinux/html/information_basic02.html ! // getestet unter Ubuntu 16.04 mit deutscher Ausgabe ! var pfad = "Systeminfos.host" + "."; var cronStr = "*/1 * * * *"; var abfrageAverageLoad = "uptime"; var abfrageUptime = "uptime -s"; ! var forceCreation = false; ! var datenpunkte = { 'uptime': { "init":0, "common": { name: 'uptime', desc: 'uptime', type: 'number', unit: 'Tag(e)', role: 'value' } }, 'Load_Average.load_average_01_min': { "init":0, "common": { name: 'mittlere Systemauslastung in der letzten Minute', desc: 'mittlere Systemauslastung in der letzten Minute', type: 'number', unit: '', role: 'value' } }, 'Load_Average.load_average_05_min': { "init":0, "common": { name: 'mittlere Systemauslastung in den letzten 5 Minuten', desc: 'mittlere Systemauslastung in den letzten 5 Minuten, zum Zeitpunkt der Abfrage', type: 'number', unit: '', role: 'value' } }, 'Load_Average.load_average_15_min': { "init":0, "common": { name: 'mittlere Systemauslastung in den letzten 15 Minuten', desc: 'mittlere Systemauslastung in den letzten 15 Minuten, zum Zeitpunkt der Abfrage', type: 'number', unit: '', role: 'value' } } }; ! function deltaDays(date1, date2) { // Delta in Tagen zwischen zwei Tagen. Format des Datums: "2016-04-26" if(!date1.match(/\d{4}-\d{1,2}-\d{1,2}/) || !date2.match(/\d{4}-\d{1,2}-\d{1,2}/)) { log("function deltaDays() hat ein ungültiges Datumsformat erhalten","warn"); log("Skript liefert ggf. ein ungültiges ergebnis"); return -1; } date1 = date1.split("-"); date2 = date2.split("-"); if(!date1 || !date2) return null; var check1 = new Date(date1[0], date1[1], date1[2]); var check2 = new Date(date2[0], date2[1], date2[2]); return Math.round(Math.abs(check1 - check2) / (1000 * 60 * 60 * 24 )); } ! function createDp() { var name; var init; var common; for (var dp in datenpunkte) { name = pfad + dp; init = datenpunkte[dp].init; common = datenpunkte[dp].common; createState(name, init , forceCreation, common); } } ! function writeDp(arr) { setState(pfad + 'Load_Average.load_average_01_min',parseFloat(arr[0])); setState(pfad + 'Load_Average.load_average_05_min',parseFloat(arr[1])); setState(pfad + 'Load_Average.load_average_15_min',parseFloat(arr[2])); } ! // Average Load mit uptime auslesen function getAverage() { exec(abfrageAverageLoad, function(err, stdout, stderr) { if (err) { log(err); return; } stdout = stdout.replace(/(.)+load average: /, ""); stdout = stdout.replace(/,/g,"."); stdout = stdout.split(". "); //log(stdout); writeDp(stdout); }); } ! // Uptime mit uptime auslesen function getUptime() { exec(abfrageUptime, function(err, stdout, stderr) { if (err) { log(err); return; } stdout = stdout.split(" "); var now = formatDate(new Date(), "YYYY-MM-DD"); setState(pfad + 'uptime',deltaDays(stdout[0],now)); }); } ! function getData() { getAverage(); getUptime(); } ! // regelmässige Wiederholungen // ----------------------------------------------------------------------------- schedule(cronStr, getData); ! // main // ----------------------------------------------------------------------------- function main() { getData(); } ! // Start Skript: // ----------------------------------------------------------------------------- ! createDp(); setTimeout(main, 500); !

    Auslastung der Fesplatte:

    ! // ermittelt auf Linuxrechner den Festplattenspeicher // mit dem Linux Befehl: df // // Beduetung der Werte: // http://www.selflinux.org/selflinux/html/information_basic02.html ! // getestet unter Ubuntu 16.04 mit deutscher Ausgabe von "df" ! // df / -h auf der Kosole muss folgende Tabelle ausgeben: ! // # df / -h // Dateisystem Größe Benutzt Verf. Verw% Eingehängt auf // /dev/mapper/ubuntu1604server--vg-root 34G 2,8G 29G 9% / ! var pfad = "Systeminfos.host.HD" + "."; var cronStr = "*/30 * * * *"; var abfrage ="df / -m"; ! var forceCreation = true; ! var datenpunkte = { 'HD_1_gesamt': { "init":0, "common": { name: 'Festplattenspeicher gesamt', desc: 'Festplattenspeicher gesamt', type: 'number', unit: 'GByte', role: 'value' } }, 'HD_2_benutzt': { "init":0, "common": { name: 'Festplattenspeicher benutzt', desc: 'Festplattenspeicher benutzt', type: 'number', unit: 'GByte', role: 'value' } }, 'HD_3_frei': { "init":0, "common": { name: 'Festplattenspeicher frei', desc: 'Festplattenspeicher frei', type: 'number', unit: 'GByte', role: 'value' } }, 'HD_4_verwendet': { "init":"", "common": { name: 'verwendeter Festplattenspeicher in %', desc: 'verwendeter Festplattenspeicher in %', type: 'number', unit: '%', role: 'value' } } }; ! function createDp() { var name; var init; var common; for (var dp in datenpunkte) { name = pfad + dp; init = datenpunkte[dp].init; common = datenpunkte[dp].common; createState(name, init , forceCreation, common); } } ! function writeDp(arr) { var wert; var i = 0; for (var dp in datenpunkte) { wert = arr[i++]; if (i !== 4 ) { wert = Math.round(wert/1024*10)/10; } else { wert = parseInt(wert); } setState(pfad + dp,wert); } } ! function freeHD() { exec(abfrage, function(err, stdout, stderr) { if (err) { log(err); return; } stdout = stdout.replace(/.+\n/, ""); // alle Zeichen vor dem ersten cr log(stdout); stdout = stdout.replace(/[\S]+[ ]+/, ""); stdout = stdout.replace("%", ""); stdout = stdout.split(/[ ]+/g); //log(stdout); writeDp(stdout); }); } ! // regelmässige Wiederholungen // ----------------------------------------------------------------------------- schedule(cronStr, freeHD); ! // main // ----------------------------------------------------------------------------- function main() { freeHD(); } ! // Start Skript: // ----------------------------------------------------------------------------- ! createDp(); setTimeout(main, 500); !

    Speicher:

    ! // ermittelt auf Linuxrechner den Speicherverbrauch // mit dem Linux Befehl: free // // Beduetung der Werte: // http://www.selflinux.org/selflinux/html/information_basic02.html ! // getestet unter Ubuntu 16.04 mit deutscher Ausgabe von "free -m" ! // free -m auf der Kosole muss folgende Tabelle ausgeben: ! //# free -m // gesamt benutzt frei gemns. Puffer/Cache verfügbar //Speicher: 7966 1238 5916 10 812 6624 //Auslagerungsspeicher: 8187 0 8187 ! var pfad = "Systeminfos.host.Speicher" + "."; var cronStr = "*/1 * * * *"; ! var forceCreation = false; ! var datenpunkte = { 'Speicher_1_gesamt': { "init":0, "common": { name: 'Speicher gesamt, der für das System verfügbar ist', desc: 'Speicher gesamt, der für das System verfügbar ist (ohne Kernel)', type: 'number', unit: 'MByte', role: 'value' } }, 'Speicher_2_benutzt': { "init":0, "common": { name: 'Speicher benutzt', desc: 'Speicher benutzt', type: 'number', unit: 'MByte', role: 'value' } }, 'Speicher_3_frei': { "init":0, "common": { name: 'Speicher frei', desc: 'Speicher frei', type: 'number', unit: 'MByte', role: 'value' } }, 'Speicher_4_gemeinsam': { "init":0, "common": { name: 'gemeinsamer Speicher für Prozesse', desc: 'gemeinsamer Speicher für Prozesse', type: 'number', unit: 'MByte', role: 'value' } }, 'Speicher_5_Buffer_Cache': { "init":0, "common": { name: 'Speicher als Cache', desc: 'Speicher als Cache', type: 'number', unit: 'MByte', role: 'value' } }, 'Speicher_6_verfügbar': { "init":0, "common": { name: 'verfügbarer Speicher', desc: 'verfügbarer Speicher', type: 'number', unit: 'MByte', role: 'value' } }, 'Auslagerungsspeicher_1_gesamt': { "init":0, "common": { name: 'Auslagerungsspeicher gesamt', desc: 'Auslagerungsspeicher gesamt', type: 'number', unit: 'MByte', role: 'value' } }, 'Auslagerungsspeicher_2_benutzt': { "init":0, "common": { name: 'Auslagerungsspeicher benutzt', desc: 'Auslagerungsspeicher benutzt', type: 'number', unit: 'MByte', role: 'value' } }, 'Auslagerungsspeicher_3_frei': { "init":0, "common": { name: 'Auslagerungsspeicher frei', desc: 'Auslagerungsspeicher frei', type: 'number', unit: 'MByte', role: 'value' } } }; ! function createDp() { var name; var init; var common; for (var dp in datenpunkte) { name = pfad + dp; init = datenpunkte[dp].init; common = datenpunkte[dp].common; createState(name, init , forceCreation, common); } } ! function writeDp(arr) { var i = 0; for (var dp in datenpunkte) { var wert = parseInt(arr[i++]); setState(pfad + dp,wert); //log(dp+": "+ wert + " #" + typeof(wert)); } } ! // Speicher mit "free -m" auslesen function freeMem() { exec('free -m', function(err, stdout, stderr) { if (err) { log(err); return; } stdout = stdout.replace(/[\D]+/, ""); // alle Zeichen vor der ersten Ziffer entfernen stdout = stdout.split(/[\D]+/g); // alle nicht-Ziffern als Trennzeichen für das Array verwenden (im Block) //log(stdout); writeDp(stdout); }); } ! // regelmässige Wiederholungen // ----------------------------------------------------------------------------- schedule(cronStr, freeMem); ! // main // ----------------------------------------------------------------------------- function main() { freeMem(); } ! // Start Skript: // ----------------------------------------------------------------------------- ! createDp(); setTimeout(main, 500); !

    Installierte Version von node.js:

    ! ````
    var pfad = "Systeminfos.ioBroker" + ".";
    var cronStr = "*/30 * * * *";
    ! var abfrage = "nodejs -v";
    ! var idNodejsVersion = pfad + 'node_js_Version';
    ! createState(idNodejsVersion, "", {
    name: 'node.js Version',
    desc: 'node.js Version (abgefragt mit nodejs -v)',
    type: 'string',
    unit: '',
    role: 'value'
    });

    ! function abfrageVersion() {
    exec(abfrage, function(err, stdout, stderr) {
    if (err) {
    log(err,"error");
    return;
    }
    //log(stdout);
    setStateDelayed(idNodejsVersion,stdout,100);
    });
    }
    ! function abfragen() {
    abfrageVersion();
    }
    ! // regelmässige Wiederholungen
    // -----------------------------------------------------------------------------
    schedule(cronStr, abfragen);
    ! // main
    // -----------------------------------------------------------------------------
    function main() {
    abfragen();
    }
    ! // Start Skript:
    // -----------------------------------------------------------------------------
    ! setTimeout(main, 500);
    ! ````

    usw.

    Die Skripte sind unter Ubuntu 16.04 getestet. Sie starten die Abfrage unter Linux und die Rückmeldung wird ausgewertet.

    Adapter: Fritzbox, Unify Circuit
    Skripte: dynamic hue, Bluetooth Scan, Multi-Ereignisliste

    1 Antwort Letzte Antwort
    0
    • ruhr70R Offline
      ruhr70R Offline
      ruhr70
      schrieb am zuletzt editiert von
      #4

      Und eine Variante der Darstellung:

      327_iobroker_host.jpg

      Adapter: Fritzbox, Unify Circuit
      Skripte: dynamic hue, Bluetooth Scan, Multi-Ereignisliste

      1 Antwort Letzte Antwort
      0
      • HomoranH Offline
        HomoranH Offline
        Homoran
        Global Moderator Administrators
        schrieb am zuletzt editiert von
        #5

        Hallo ruhr70,

        Selbst schuld, wenn du dich hier meldest :D

        Du hast ja das script zum auslesen der ioBroker Prozesse geschrieben.

        Kannst du das um die Hintergrundprozesse wie redis-server und mysqld oder influxd erweitern?

        …und %cpu used... aus dem header von top

        Oder mir per PN erklären, wie du da ran kommst.

        Gruß

        Rainer

        kein Support per PN! - Fragen im Forum stellen - es gibt fast nichts, was nicht auch für andere interessant ist.

        Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

        der Installationsfixer: curl -fsL https://iobroker.net/fix.sh | bash -

        1 Antwort Letzte Antwort
        0
        • HomoranH Offline
          HomoranH Offline
          Homoran
          Global Moderator Administrators
          schrieb am zuletzt editiert von
          #6

          Und hier mal mein momentaner Stand beim Cubietruck
          144_screenshot_20170305-101517.jpg

          Da kommen noch die Werte vom Akkumanagement dazu.

          Muss aber einen zweiten cubie mit Akku fertigmachen.

          Gruß

          Rainer

          kein Support per PN! - Fragen im Forum stellen - es gibt fast nichts, was nicht auch für andere interessant ist.

          Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

          der Installationsfixer: curl -fsL https://iobroker.net/fix.sh | bash -

          1 Antwort Letzte Antwort
          0
          • ruhr70R Offline
            ruhr70R Offline
            ruhr70
            schrieb am zuletzt editiert von
            #7

            @Homoran:

            Hallo ruhr70,

            Selbst schuld, wenn du dich hier meldest :D

            Du hast ja das script zum auslesen der ioBroker Prozesse geschrieben.

            Kannst du das um die Hintergrundprozesse wie redis-server und mysqld oder influxd erweitern?

            …und %cpu used... aus dem header von top `

            Was hältst Du von Arbeitsteilung ;-)

            Du postest die Linux-Abfragen und ich schreib das Skript welches die Werte parst. :mrgreen:

            Adapter: Fritzbox, Unify Circuit
            Skripte: dynamic hue, Bluetooth Scan, Multi-Ereignisliste

            1 Antwort Letzte Antwort
            0
            • I Offline
              I Offline
              Ingo
              schrieb am zuletzt editiert von
              #8

              Danke, kapiert.

              Schau dir mal an:

              http://www.gargi.org/showthread.php?122 … s-auslesen

              Ich habe dies installiert, kriege letztendlich dies angezeigt:

              Grüße Ingo

              Brix 3150, Debian, IoBroker

              RPi3 Raspberrymatic, Arduino Mega mit RF-Link 433 MHz, Echo Dot,

              RPi3 Magic Mirror mit View-Wechsel

              Xiaomi Gateway mit div. Sensoren

              1 Antwort Letzte Antwort
              0
              • ruhr70R Offline
                ruhr70R Offline
                ruhr70
                schrieb am zuletzt editiert von
                #9

                mmh… das sieht sehr individuell aus und dürfte bei jedem Rechner eine andere Ausgabe erzeugen.

                Hat auch nicht hiermit zu tun oder:

                ` > Kannst du das um die Hintergrundprozesse wie redis-server und mysqld oder influxd erweitern?

                …und %cpu used... aus dem header von top `

                Sollen wir damit nicht anfangen? ;-)

                Adapter: Fritzbox, Unify Circuit
                Skripte: dynamic hue, Bluetooth Scan, Multi-Ereignisliste

                1 Antwort Letzte Antwort
                0
                • HomoranH Offline
                  HomoranH Offline
                  Homoran
                  Global Moderator Administrators
                  schrieb am zuletzt editiert von
                  #10

                  Hallo ruhr70,

                  da haben sich zwei Anfragen überschnitten!

                  Das letzte war für mich.

                  @ruhr70:

                  Sollen wir damit nicht anfangen? `
                  Ja!

                  @ruhr70:

                  Was hältst Du von Arbeitsteilung

                  Du postest die Linux-Abfragen und ich schreib das Skript welches die Werte parst. `
                  gerne, aber genau das weiß ich ja nicht :(

                  Nicht lachen, aber du fragst doch auch irgendwie mit grep(?) nach "io." ab, oder?

                  und dann zusätzlich (wenn ich es jetzt langsam richtig lerne mit | und "redis-server" und "| influxd | mysqld" ?????

                  nur so rein theoretisch von einem js-Legastheniker :oops:

                  Gruß

                  Rainer

                  kein Support per PN! - Fragen im Forum stellen - es gibt fast nichts, was nicht auch für andere interessant ist.

                  Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

                  der Installationsfixer: curl -fsL https://iobroker.net/fix.sh | bash -

                  1 Antwort Letzte Antwort
                  0
                  • ruhr70R Offline
                    ruhr70R Offline
                    ruhr70
                    schrieb am zuletzt editiert von
                    #11

                    @Homoran:

                    , aber du fragst doch auch irgendwie mit grep(?) nach "io." ab, oder?

                    und dann zusätzlich (wenn ich es jetzt langsam richtig lerne mit | und "redis-server" und "| influxd | mysqld" ????? `

                    He he…. deswegen ja die Arbeitsteilung... das Parsen bekomme ich noch hin...

                    die Linux Abfragen muss ich mir auch jedes Mal zusammensuchen.

                    Die ioBroker Prozesse frage ich so ab:

                    `ps -A aux --sort -pmem | grep " [i]o.*"`[/i]
                    

                    Adapter: Fritzbox, Unify Circuit
                    Skripte: dynamic hue, Bluetooth Scan, Multi-Ereignisliste

                    1 Antwort Letzte Antwort
                    0
                    • HomoranH Offline
                      HomoranH Offline
                      Homoran
                      Global Moderator Administrators
                      schrieb am zuletzt editiert von
                      #12

                      @ruhr70:

                      Die ioBroker Prozesse frage ich so ab: `

                      Danke,

                      Bis gleich

                      Rainer

                      kein Support per PN! - Fragen im Forum stellen - es gibt fast nichts, was nicht auch für andere interessant ist.

                      Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

                      der Installationsfixer: curl -fsL https://iobroker.net/fix.sh | bash -

                      1 Antwort Letzte Antwort
                      0
                      • HomoranH Offline
                        HomoranH Offline
                        Homoran
                        Global Moderator Administrators
                        schrieb am zuletzt editiert von
                        #13

                        Hallo ruhr70

                         ps -A aux --sort -pcpu | grep "redis-server"
                        

                        Hier kommen leider zwei:

                        root@ioBroker-Cubie:~# ps -A aux --sort -pcpu | grep "mysqld"
                        mysql     1295  1.9  8.2 363056 171120 ?       Sl   Feb21 348:11 /usr/sbin/mysqld --basedir=/usr --datadir=/var/lib/mysql --plugin-dir=/usr/lib/mysql/plugin --user=mysql --log-error=/var/log/mysql/error.log --pid-file=/var/run/mysqld/mysqld.pid --socket=/var/run/mysqld/mysqld.sock --port=3306
                        root       732  0.0  0.0   1440   104 ?        S    Feb21   0:00 /bin/sh /usr/bin/mysqld_safe
                        root      2680  0.0  0.0   5624  2000 pts/0    S+   11:39   0:00 grep mysqld
                        
                        

                        Die header von top versuche ich gleich noch

                        Gruß

                        Rainer

                        kein Support per PN! - Fragen im Forum stellen - es gibt fast nichts, was nicht auch für andere interessant ist.

                        Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

                        der Installationsfixer: curl -fsL https://iobroker.net/fix.sh | bash -

                        1 Antwort Letzte Antwort
                        0
                        • HomoranH Offline
                          HomoranH Offline
                          Homoran
                          Global Moderator Administrators
                          schrieb am zuletzt editiert von
                          #14

                          @Homoran:

                          Die header von top versuche ich gleich noch `
                          google hilft, aber kann das sein:

                           top -bn1 | grep "Cpu(s)" |            sed "s/.*, *\([0-9.]*\)%* id.*/\1/" |            awk '{print 100 - $1"%"}'
                          
                          

                          da kommt bei mir 97% raus.

                          oder muss das noch durch die Zahl der Kerne geteilt werden?

                          EDIT:

                          oben ist anscheinend Mist, das hier scheint zu funktionieren:

                           top -d 0.5 -b -n2 | grep "Cpu(s)"|tail -n 1 | awk '{print $2}'
                          

                          EDIT2:

                          Auf dem Pine64 mit influxDB:

                          brokerio@ioBroker_Pine64:~$ ps -A aux --sort -pcpu | grep "influxd"
                          influxdb  9822  2.4  7.0 830996 144164 ?       Ssl   2016 3416:05 /usr/bin/influxd -config /etc/influxdb/influxdb.conf
                          root     15502  1.1  2.0 1200848 41692 ?       Sl   Feb24 144:51 io.influxdb.0                                                   
                          brokerio  4550  0.0  0.0   6148   944 pts/0    S+   12:04   0:00 grep influxd
                          
                          

                          EDIT3:

                          der code bei Edit bringt nur die CPU-Usage durch User-Programme, dieses hier:

                          top -d 0.5 -b -n2 | grep "Cpu(s)"|tail -n 1 | awk '{print $2 + $3 + $4}'
                          

                          bringt zusätzlich noch die System und die Nice - Programme (addiert)

                          Gruß

                          Rainer

                          kein Support per PN! - Fragen im Forum stellen - es gibt fast nichts, was nicht auch für andere interessant ist.

                          Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

                          der Installationsfixer: curl -fsL https://iobroker.net/fix.sh | bash -

                          1 Antwort Letzte Antwort
                          0
                          • ruhr70R Offline
                            ruhr70R Offline
                            ruhr70
                            schrieb am zuletzt editiert von
                            #15

                            mhhh… wird schwierig...

                            michael@ubuntu1604server:~/dhtest-master$ top -d 0.5 -b -n2 | grep "Cpu(s)"|tail -n 1 | awk '{print $2}'
                            top: ungültiges Verzögerungsintervall »0.5«
                            michael@ubuntu1604server:~/dhtest-master$ 
                            michael@ubuntu1604server:~/dhtest-master$ top -d 0.5 -b -n2 | grep "Cpu(s)"|tail -n 1 | awk '{print $2 + $3 + $4}'
                            top: ungültiges Verzögerungsintervall »0.5«
                            michael@ubuntu1604server:~/dhtest-master$ 
                            
                            

                            Adapter: Fritzbox, Unify Circuit
                            Skripte: dynamic hue, Bluetooth Scan, Multi-Ereignisliste

                            1 Antwort Letzte Antwort
                            0
                            • HomoranH Offline
                              HomoranH Offline
                              Homoran
                              Global Moderator Administrators
                              schrieb am zuletzt editiert von
                              #16

                              Ubuntu! :D

                              @ruhr70:

                              ungültiges Verzögerungsintervall »0.5« `
                              Das Verzögerungsintervall ist notwendig, das tatsächlich die Abfrage ohne Verzögerung falsch hohe Werte liefert.

                              Habe (leider wäre gelogen) kein Ubuntu zum Testen.

                              Klappt es bei dir mit Ganzzahlen?

                              Gruß

                              Rainer

                              kein Support per PN! - Fragen im Forum stellen - es gibt fast nichts, was nicht auch für andere interessant ist.

                              Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

                              der Installationsfixer: curl -fsL https://iobroker.net/fix.sh | bash -

                              1 Antwort Letzte Antwort
                              0
                              • ruhr70R Offline
                                ruhr70R Offline
                                ruhr70
                                schrieb am zuletzt editiert von
                                #17
                                michael@ubuntu1604server:~/dhtest-master$ top -d 1 -b -n2 | grep "Cpu(s)"|tail -n 1 | awk '{print $2 + $3 + $4}'
                                michael@ubuntu1604server:~/dhtest-master$ top -d 1 -b -n2 | grep "Cpu(s)"|tail -n 1 | awk '{print $2}'
                                michael@ubuntu1604server:~/dhtest-master$ 
                                

                                kein Fehler

                                keine Ausgabe

                                Adapter: Fritzbox, Unify Circuit
                                Skripte: dynamic hue, Bluetooth Scan, Multi-Ereignisliste

                                1 Antwort Letzte Antwort
                                0
                                • HomoranH Offline
                                  HomoranH Offline
                                  Homoran
                                  Global Moderator Administrators
                                  schrieb am zuletzt editiert von
                                  #18

                                  @ruhr70:

                                  kein Fehler

                                  keine Ausgabe ` :shock:

                                  Habe das bei dir rauskopiert:

                                  root@ioBroker-Cubie:~# top -d 1 -b -n2 | grep "Cpu(s)"|tail -n 1 | awk '{print $2 + $3 + $4}'
                                  88
                                  root@ioBroker-Cubie:~# top -d 1 -b -n2 | grep "Cpu(s)"|tail -n 1 | awk '{print $2}'
                                  31,9
                                  root@ioBroker-Cubie:~#
                                  
                                  

                                  wie sieht denn bei dir der Header im Ubuntu-top aus?

                                  • Groß, Kleinschreibung?

                                  • root?

                                  Gruß

                                  Rainer

                                  kein Support per PN! - Fragen im Forum stellen - es gibt fast nichts, was nicht auch für andere interessant ist.

                                  Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

                                  der Installationsfixer: curl -fsL https://iobroker.net/fix.sh | bash -

                                  1 Antwort Letzte Antwort
                                  0
                                  • lobomauL Offline
                                    lobomauL Offline
                                    lobomau
                                    schrieb am zuletzt editiert von
                                    #19

                                    @Ingo:

                                    Bin vor kurzem vom Raspberry 3 auf einen Gigabyte Brix 3150 umgestiegen, da komme ich mit dem RPI-Monitor wohl nicht weit.

                                    Es ist also eine Debian-Minimal-Installation geworden, (ohne Desktop), dann IoBroker installiert, läuft super.

                                    Hardware: Gigabyte Brix 3150 mit 8 GB RAM und 120 GB SSD.

                                    swerte haben, etwa analog zum RPI-Monitor.

                                    Ich habe lm-sensors installiert, kriege aber letztendlich nur die CPU-Temperatur heraus.

                                    Auf Homorans Rat den RPI-Monitor installiert.. `
                                    Hab ihn auch, Unterschied: ubuntu Server und 4Gb RAM.

                                    Läuft auch Top. BT-Script läuft und RFlink.

                                    Fehler hatte ich auch mit RPI Adapter. Hab dann paar Werte deaktiviert, die Fehler zeigten. Ob die anderen Werte korrekt sind, ist zu bezweifeln: kleinste CPU Geschwindigkeit ist zu klein.

                                    lm-sensors muss ich mal ausprobieren.

                                    Host: NUC8i3 mit Proxmox:

                                    • ioBroker CT Debian 13, npm 10.9.4, nodejs 22.21.0
                                    • Slave: Pi4
                                    1 Antwort Letzte Antwort
                                    0
                                    • I Offline
                                      I Offline
                                      Ingo
                                      schrieb am zuletzt editiert von
                                      #20

                                      Moin, Moin,

                                      ich habe mich jetzt stundenlang durch die JavaScript-Anleitung gewühlt.

                                      Die Scripte von ruhr70 habe ich eingearbeitet bekommen, sie liefern mir

                                      unter Objecte auch brauchbare Resultate.

                                      Beim Starten der Scripts gab es keine Fehlermeldungen, also sollte es unter Debian

                                      auch funktionieren.

                                      Mein Dank an ruhr70 dafür !

                                      Mein Gott, was steckt da Arbeit drin.

                                      Gibt es noch mehr Scripte dazu von dir ?

                                      Grüße Ingo

                                      Brix 3150, Debian, IoBroker

                                      RPi3 Raspberrymatic, Arduino Mega mit RF-Link 433 MHz, Echo Dot,

                                      RPi3 Magic Mirror mit View-Wechsel

                                      Xiaomi Gateway mit div. Sensoren

                                      1 Antwort Letzte Antwort
                                      0
                                      • ruhr70R Offline
                                        ruhr70R Offline
                                        ruhr70
                                        schrieb am zuletzt editiert von
                                        #21

                                        @Ingo:

                                        Gibt es noch mehr Scripte dazu von dir ? `

                                        ja. Ein paar Skripte habe ich noch.

                                        Abfrage nach verfügbaren Updates / Security Updates:

                                        ! ````
                                        var pfad = "Systeminfos.host.updates" + ".";
                                        var cronStr = "*/5 * * * *";
                                        ! var abfrage = "cat /var/lib/update-notifier/updates-available";
                                        ! var idUpdatesAll = pfad + 'Updates_verfügbar';
                                        var idUpdatesSec = pfad + 'Security_Updates';
                                        ! createState(idUpdatesAll, 0, {
                                        name: 'Ubuntu Updates verfügbar',
                                        desc: 'Ubuntu Updates verfügbar',
                                        type: 'number',
                                        unit: '',
                                        role: 'value'
                                        });

                                        createState(idUpdatesSec, 0, {
                                        name: 'Ubuntu Securtity Updates verfügbar',
                                        desc: 'Ubuntu Securtity Updates verfügbar',
                                        type: 'number',
                                        unit: '',
                                        role: 'value'
                                        });

                                        ! function abfrageUpdates() {
                                        exec(abfrage, function(err, stdout, stderr) {
                                        if (err) {
                                        log(err,"error");
                                        return;
                                        }
                                        //log(stdout);
                                        if (stdout.indexOf("Keine Berechtigung") != -1) {
                                        log('Keine Berechtigung für "cat /var/lib/update-notifier/updates-available"',"warn");
                                        setStateDelayed(idUpdatesAll,-1);
                                        setStateDelayed(idUpdatesSec,-1);
                                        } else {
                                        //stdout = stdout.replace(/[\D]+/g, ""); // alle Zeichen vor der ersten Ziffer entfernen
                                        stdout = stdout.replace(/\n/, ""); // Ersten Zeilenumbruch entfernen
                                        //log(stdout);
                                        stdout = stdout.split(/[\D]+/g); // alle nicht-Ziffern als Trennzeichen für das Array verwenden (im Block)
                                        //log(stdout);
                                        //log(stdout[0]);
                                        setState(idUpdatesAll,parseInt(stdout[0]));
                                        setState(idUpdatesSec,parseInt(stdout[1]));
                                        }
                                        });
                                        }
                                        ! function abfragen() {
                                        abfrageUpdates();
                                        }
                                        ! // regelmässige Wiederholungen
                                        // -----------------------------------------------------------------------------
                                        schedule(cronStr, abfragen);
                                        ! // main
                                        // -----------------------------------------------------------------------------
                                        function main() {
                                        abfragen();
                                        }
                                        ! // Start Skript:
                                        // -----------------------------------------------------------------------------
                                        ! setTimeout(main, 500);
                                        ! ````

                                        Fesplattenplatz, den ioBroker verbraucht:

                                        ! ````
                                        // ermittelt auf Linuxrechner den Festplattenplatz für ioBroker
                                        // mit dem Linux Befehl: du
                                        ! var pfad = "Systeminfos.ioBroker" + ".";
                                        var cronStr = "*/30 * * * *";
                                        ! var abfrageGesamt ="du /opt/iobroker -s -m";
                                        var abfrageData ="du /opt/iobroker/iobroker-data -s -m";
                                        var abfrageObjects ="du /opt/iobroker/iobroker-data/objects.json -s -k";
                                        var abfrageStates ="du /opt/iobroker/iobroker-data/states.json -s -k";
                                        var abfrageLog ="du /opt/iobroker/log -s -k";
                                        ! var idHdGesamt = pfad + 'HD_gesamt';
                                        var idHdData = pfad + 'HD_iobroker_data';
                                        var idHdObjects = pfad + 'HD_objects_json';
                                        var idHdStates = pfad + 'HD_states_json';
                                        var idHdLog = pfad + 'HD_log';
                                        ! createState(idHdGesamt, 0, {
                                        name: 'Festplattenplatz ioBroker gesamt',
                                        desc: 'Festplattenplatz ioBroker gesamt',
                                        type: 'number',
                                        unit: 'MByte',
                                        role: 'value'
                                        });

                                        createState(idHdData, 0, {
                                        name: 'Festplattenplatz ioBroker-data',
                                        desc: 'Festplattenplatz ioBroker-data',
                                        type: 'number',
                                        unit: 'MByte',
                                        role: 'value'
                                        });

                                        ! createState(idHdStates, 0, {
                                        name: 'Festplattenplatz states.json',
                                        desc: 'Festplattenplatz states.json',
                                        type: 'number',
                                        unit: 'kByte',
                                        role: 'value'
                                        });
                                        ! createState(idHdObjects, 0, {
                                        name: 'Festplattenplatz objects.json',
                                        desc: 'Festplattenplatz objects.json',
                                        type: 'number',
                                        unit: 'kByte',
                                        role: 'value'
                                        });
                                        ! createState(idHdLog, 0, {
                                        name: 'Festplattenplatz ioBroker Log-Files',
                                        desc: 'Festplattenplatz ioBroker Log-Files',
                                        type: 'number',
                                        unit: 'kByte',
                                        role: 'value'
                                        });
                                        ! // Belegung Festplattenplatz für ioBroker mit "du" auslesen
                                        function abfrageHD(abfrage,dp) {
                                        exec(abfrage, function(err, stdout, stderr) {
                                        if (err) {
                                        log(err,"error");
                                        return;
                                        }
                                        stdout = stdout.replace(/[\D]+/, ""); // alle nicht-Ziffern entfernen
                                        setState(dp,parseInt(stdout));
                                        });
                                        }
                                        ! function abfragen() {
                                        abfrageHD(abfrageGesamt,idHdGesamt);
                                        abfrageHD(abfrageData,idHdData);
                                        abfrageHD(abfrageObjects,idHdObjects);
                                        abfrageHD(abfrageStates,idHdStates);
                                        abfrageHD(abfrageLog,idHdLog);
                                        }
                                        ! // regelmässige Wiederholungen
                                        // -----------------------------------------------------------------------------
                                        schedule(cronStr, abfragen);
                                        ! // main
                                        // -----------------------------------------------------------------------------
                                        function main() {
                                        abfragen();
                                        }
                                        ! // Start Skript:
                                        // -----------------------------------------------------------------------------
                                        ! setTimeout(main, 500);
                                        ! ````

                                        Abfrage Version npm:

                                        ! ````
                                        var pfad = "Systeminfos.ioBroker" + ".";
                                        var cronStr = "*/30 * * * *";
                                        ! var abfrage = "npm -v";
                                        ! var idNpmVersion = pfad + 'npm_Version';
                                        ! createState(idNpmVersion, "", {
                                        name: 'npm Version',
                                        desc: 'npm Version (abgefragt mit npm -v)',
                                        type: 'string',
                                        unit: '',
                                        role: 'value'
                                        });

                                        ! function abfrageVersion() {
                                        exec(abfrage, function(err, stdout, stderr) {
                                        if (err) {
                                        log(err,"error");
                                        return;
                                        }
                                        //log(stdout);
                                        setStateDelayed(idNpmVersion,stdout,100);
                                        });
                                        }
                                        ! function abfragen() {
                                        abfrageVersion();
                                        }
                                        ! // regelmässige Wiederholungen
                                        // -----------------------------------------------------------------------------
                                        schedule(cronStr, abfragen);
                                        ! // main
                                        // -----------------------------------------------------------------------------
                                        function main() {
                                        abfragen();
                                        }
                                        ! // Start Skript:
                                        // -----------------------------------------------------------------------------
                                        ! setTimeout(main, 500);
                                        ! ````

                                        Uptime ioBroker (oben war es die Updike vom Linux Host):

                                        ! // system.host.ubuntu1604server.uptime ! var pfad = "Systeminfos.ioBroker" + "."; var idState = "uptime"; ! createState(pfad + idState, 0, { name: 'ioBroker uptime', desc: 'ioBroker uptime', type: 'number', unit: '', role: 'value' }); ! on({id:"system.host.ubuntu1604server.uptime",change:'any'}, function (obj) { setState(pfad + idState,Math.floor((obj.newState.val/3600)/24)); }); ! // main // ----------------------------------------------------------------------------- function main() { // } ! // Start Skript: // ----------------------------------------------------------------------------- ! setTimeout(main, 500); !

                                        Wenn unter vmware installiert, Anzahl der zugewiesenen vCPUs:

                                        ! var pfad = "Systeminfos.host" + "."; // Pfad in dem die Datenpunkte angelegt werden ! // Datenpunktnamen: var idAnzVcpu = pfad + 'Anzahl_CPUs'; ! // regelmässige Wiederholungen der Abfrage var cronStr = "*/30 * * * *"; ! var abfrage = 'ls -1 /sys/devices/system/cpu|grep [0-9]|wc -l'; ! // ----------------------------------------------------------------------------- ! createState(idAnzVcpu, 0, { name: 'Host Anzahl vCPUs', desc: 'Host Anzahl vCPUs', type: 'number', unit: '', role: 'value' }); ! // ----------------------------------------------------------------------------- ! function abfrageConsole() { exec(abfrage, function(err, stdout, stderr) { if (err) { log(err,"error"); return; } var vCpus = parseInt(stdout); setState(idAnzVcpu ,vCpus); }); } ! function abfragen() { abfrageConsole(); } ! // regelmässige Wiederholungen // ----------------------------------------------------------------------------- schedule(cronStr, abfragen); ! // main // ----------------------------------------------------------------------------- function main() { abfragen(); } ! // Start Skript: // ----------------------------------------------------------------------------- ! setTimeout(main, 500); !

                                        Wenn Du eine hue Bridge hast… Abfrage, ob die Firmware aktuell ist und ob es für die Lampen ein update gibt:

                                        (IP anpassen):

                                        ! ````
                                        ! // scriptEnabled wird von anderen Skripten verwendet:
                                        // ...
                                        ! request = require('request');
                                        ! var url ="http://172.16.130.126/api/newdeveloper";
                                        var timeout = 3000;
                                        ! var pfad = "Systeminfos.hue" + "."; // Pfad Systeminfos zur hue Bridge
                                        var cronStr = "*/30 * * * *";
                                        ! var idUpdateAv = pfad + 'Bridge_Update_Verfügbar';
                                        var idUpdateLights = pfad + 'Lights_Update_Anzahl';
                                        var idUpdateSensors = pfad + 'Sensors_Update_Anzahl';
                                        var idZigbeeChannel = pfad + 'Zigbee_Channel';
                                        ! var idSWVersion = pfad + 'Bride_SW_Version';
                                        var idApiVersion = pfad + 'Bride_API_Version';
                                        ! var idHueStatusBool = pfad + 'Status_http_bool';
                                        ! createState(idHueStatusBool, false, {
                                        name: 'Status Webseite hue bool',
                                        desc: 'Status Webseite hue bool',
                                        type: 'boolean',
                                        unit: '',
                                        role: 'value'
                                        });
                                        ! createState(idUpdateAv, false, {
                                        name: 'Update für die hue Bridge verfügbar',
                                        desc: 'Update für die hue Bridge verfügbar',
                                        type: 'boolean',
                                        unit: '',
                                        role: 'value'
                                        });
                                        ! createState(idUpdateLights, 0, {
                                        name: 'Anzahl hue Lights mit Update',
                                        desc: 'Anzahl hue Lights mit Update',
                                        type: 'number',
                                        unit: '',
                                        role: 'value'
                                        });
                                        ! createState(idUpdateSensors, 0, {
                                        name: 'Anzahl hue Senosrs mit Update',
                                        desc: 'Anzahl hue Sensors mit Update',
                                        type: 'number',
                                        unit: '',
                                        role: 'value'
                                        });
                                        ! createState(idZigbeeChannel, 0, {
                                        name: 'Zigbee Channel',
                                        desc: 'Zigbee Channel',
                                        type: 'number',
                                        unit: '',
                                        role: 'value'
                                        });
                                        ! createState(idSWVersion, "init", {
                                        name: 'hue Bridge SW Version',
                                        desc: 'hue Bridge SW Version',
                                        type: 'string',
                                        unit: '',
                                        role: 'value'
                                        });
                                        ! createState(idApiVersion, "init", {
                                        name: 'hue Bridge API Version',
                                        desc: 'hue Bridge API Version',
                                        type: 'string',
                                        unit: '',
                                        role: 'value'
                                        });
                                        ! var options = {
                                        url: url= url,
                                        timeout: timeout,
                                        headers: {
                                        'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; WOW64; rv:40.0) Gecko/20100101 Firefox/40.1'
                                        }
                                        };
                                        ! function readWeb(url) {
                                        try {
                                        request(options, function (error, response, body) {
                                        if (!error && ('' + response.statusCode).match(/^2\d\d$/)) { // kein Fehler (2xx), Inhalt in body
                                        log(response.statusCode);

                                                    json = JSON.parse(body);
                                        
                                                    var sWVersion       = json.config.swversion;
                                                    var apiVersion      = json.config.apiversion;
                                                    var updateStatus    = json.config.swupdate.updatestate;
                                                    var zigbeeChannel   = json.config.zigbeechannel;
                                        

                                        ! var updateAvailable = false;
                                        var updateBridge = false;
                                        var updateLights = 0;
                                        var updateSemsors = 0;

                                                    if (updateStatus > 1) {
                                                        updateAv        = json.config.swupdate.devicetypes.bridge;
                                                        updateLights    = json.config.swupdate.devicetypes.lights.length;
                                                        updateSemsors   = json.config.swupdate.devicetypes.sensors.length;
                                                        updateAvailable = true;
                                                    }
                                        

                                        ! /*
                                        log(updateBridge);
                                        log(sWVersion);
                                        log(apiVersion);
                                        log(updateLights);
                                        log(updateSemsors);
                                        */
                                        ! setState(idUpdateAv ,updateAvailable);
                                        setState(idApiVersion ,apiVersion);
                                        setState(idSWVersion ,sWVersion);
                                        setState(idUpdateLights ,updateLights);
                                        setState(idUpdateSensors ,updateSemsors);
                                        setState(idZigbeeChannel ,zigbeeChannel);
                                        setState(idHueStatusBool ,true);

                                                } else { // Fehler bei der Abfrage der CUxD Webseite
                                                    //log("StatusCode="+response.statusCode);
                                                    log("ERROR CODE: " + error.code + " ################");
                                                    // EHOSTUNREACH, ETIMEDOUT
                                                    if (!error) {
                                                        log("response.statusCode: " + response.statusCode);
                                                    } else {
                                                        //
                                                    }
                                                    log(error,'error');
                                        
                                                    setState(idUpdateAv,"Fehler");
                                                    setState(idHueStatusBool    ,false);
                                        
                                                    /*
                                                    setTimeout(function(l) { // bei Fehler jede Stunde abfragen
                                                            readWeb(url);
                                                    },3600000);
                                                    */
                                                }
                                            });
                                        } catch (error) {
                                            log('Fehler (try) leseWebseite: ' + error, 'error');
                                        }   
                                        

                                        }

                                        ! // regelmässige Wiederholungen
                                        // -----------------------------------------------------------------------------
                                        schedule(cronStr, function () {
                                        readWeb(url);
                                        });
                                        ! // main
                                        // -----------------------------------------------------------------------------
                                        function main() {
                                        readWeb(url);
                                        }
                                        ! // Start Skript:
                                        // -----------------------------------------------------------------------------
                                        setTimeout(main, 500);
                                        ! ````

                                        Adapter: Fritzbox, Unify Circuit
                                        Skripte: dynamic hue, Bluetooth Scan, Multi-Ereignisliste

                                        1 Antwort Letzte Antwort
                                        0
                                        • ruhr70R Offline
                                          ruhr70R Offline
                                          ruhr70
                                          schrieb am zuletzt editiert von
                                          #22

                                          ob das ioBroker Forum erreichbar ist:

                                          ! ````
                                          // Überwacht eine Adresse (FQDN oder IP) auf Erreichbarkeit eines Ports
                                          // z.B. Port 80 für einen Webserver
                                          ! var pfad = "Service.www.ioBroker_Forum" + ".";
                                          var cronStr = "*/10 * * * *";
                                          var webserver = "forum.iobroker.net";
                                          var port = "80";
                                          ! var logging = false;
                                          ! var abfrage = "telnet "+ webserver + " " + port;
                                          var forceCreation = false;
                                          ! var datenpunkte = {
                                          'status': {
                                          "init":false,
                                          "common": {
                                          name: 'status ' + webserver,
                                          desc: 'status ' + webserver + '. Port ' + port + ' erreichbar?',
                                          type: 'boolean',
                                          unit: '',
                                          role: 'value'
                                          }
                                          }
                                          };
                                          ! function createDp() {
                                          var name;
                                          var init;
                                          var common;
                                          for (var dp in datenpunkte) {
                                          name = pfad + dp;
                                          init = datenpunkte[dp].init;
                                          common = datenpunkte[dp].common;
                                          createState(name, init , forceCreation, common);
                                          }
                                          }
                                          ! function fehler() {
                                          if (logging)log(webserver + ": Webseite nicht erreichbar","warn");
                                          setState(pfad + "status",false);
                                          }
                                          ! function keinFehler() {
                                          if (logging)log(webserver + ": Webserver auf Port 80 erreichbar","info");
                                          setState(pfad + "status",true);
                                          }
                                          ! function getStatusPort() {
                                          exec(abfrage, function(err, stdout, stderr) {
                                          if (err) {
                                          if (logging) log("err: " + err);
                                          if (logging) log("stderr: " + stderr);
                                          if (stderr.indexOf("Connection closed by foreign host").toString() != -1) {
                                          keinFehler();
                                          return;
                                          }
                                          fehler();
                                          return;
                                          }
                                          ! if (logging) log("stdout:" + stdout);
                                          keinFehler();
                                          });
                                          }
                                          ! //
                                          on({id:"javascript."+instance+"."+pfad+"status",change:'ne'}, function (obj) {

                                          if(obj.state.val) {
                                              sayit("Webseite iobroker Forum ist erreichbar");
                                              event("Webseite iobroker Forum ist erreichbar");
                                          } else {
                                              sayit("Webseite iobroker Forum ist nicht erreichbar");
                                              event("Webseite iobroker Forum ist **nicht** erreichbar");
                                          }
                                          

                                          });

                                          ! // regelmässige Wiederholungen
                                          // -----------------------------------------------------------------------------
                                          schedule(cronStr, getStatusPort);
                                          ! // main
                                          // -----------------------------------------------------------------------------
                                          function main() {
                                          getStatusPort();
                                          }
                                          ! // Start Skript:
                                          // -----------------------------------------------------------------------------
                                          ! createDp();
                                          setTimeout(main, 500);
                                          ! ````

                                          Adapter: Fritzbox, Unify Circuit
                                          Skripte: dynamic hue, Bluetooth Scan, Multi-Ereignisliste

                                          1 Antwort Letzte Antwort
                                          0
                                          Antworten
                                          • In einem neuen Thema antworten
                                          Anmelden zum Antworten
                                          • Älteste zuerst
                                          • Neuste zuerst
                                          • Meiste Stimmen


                                          Support us

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

                                          356

                                          Online

                                          32.6k

                                          Benutzer

                                          81.9k

                                          Themen

                                          1.3m

                                          Beiträge
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Anmelden

                                          • Du hast noch kein Konto? Registrieren

                                          • Anmelden oder registrieren, um zu suchen
                                          • Erster Beitrag
                                            Letzter Beitrag
                                          0
                                          • Home
                                          • Aktuell
                                          • Tags
                                          • Ungelesen 0
                                          • Kategorien
                                          • Unreplied
                                          • Beliebt
                                          • GitHub
                                          • Docu
                                          • Hilfe