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. Skripten / Logik
  4. [Frage] ioBroker - iLO Server Daten auslesen

NEWS

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    16
    1
    1.6k

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

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.1k

[Frage] ioBroker - iLO Server Daten auslesen

Geplant Angeheftet Gesperrt Verschoben Skripten / Logik
44 Beiträge 5 Kommentatoren 6.8k Aufrufe 2 Watching
  • Ä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.
  • DutchmanD Offline
    DutchmanD Offline
    Dutchman
    Developer Most Active Administrators
    schrieb am zuletzt editiert von
    #18

    @nobse:

    Wie meinst du das
    > diese Werte als object im Baum weg zu schreiben wo auch die Daten stehen `

    Dein Script erstellt objecte und füllt diese mit Werten.

    Mein Vorschlag würde dies auch Max Werte machen wodurch wir zB den alarmwert (zb 70 Grad) per vis ändern könnten.

    Dan muss man nicht immer ins Script um diese Werte zu setzen

    –-----------------------

    Send from mobile device

    1 Antwort Letzte Antwort
    0
    • N Offline
      N Offline
      nobse
      schrieb am zuletzt editiert von
      #19

      Wenn ich dich richtig verstehe im script noch einen Datenpunkt anlegen mit dem max wert.

      Das wollte ich ja machen und den max wert aus der hardware lesen.

      Oder stehe ich jetzt auf dem Schlauch. :D

      Gruß Norbert

      CCU2 • Raspberry für Wetterstation • CMS http://www.exv2.de • HP ProLiant MicroServer Gen8 12GB RAM, 2x3TB, Windows Essentials Server 2016 mit ioBroker

      1 Antwort Letzte Antwort
      0
      • DutchmanD Offline
        DutchmanD Offline
        Dutchman
        Developer Most Active Administrators
        schrieb am zuletzt editiert von
        #20

        @nobse:

        Wenn ich dich richtig verstehe im script noch einen Datenpunkt anlegen mit dem max wert.

        Das wollte ich ja machen und den max wert aus der hardware lesen.

        Oder stehe ich jetzt auf dem Schlauch. :D `

        Nope ich hab dich falsch verstanden sieht gut aus weiter so [emoji3]

        –-----------------------

        Send from mobile device

        1 Antwort Letzte Antwort
        0
        • N Offline
          N Offline
          nobse
          schrieb am zuletzt editiert von
          #21

          Muss man den Max Werte den Editieren können?

          Eigentlich reicht es wenn abgefragt wird ob der aktuelle Wert >= dem max wert ist und dann eine Benachrichtigung sendet oder?

          Gruß Norbert

          CCU2 • Raspberry für Wetterstation • CMS http://www.exv2.de • HP ProLiant MicroServer Gen8 12GB RAM, 2x3TB, Windows Essentials Server 2016 mit ioBroker

          1 Antwort Letzte Antwort
          0
          • DutchmanD Offline
            DutchmanD Offline
            Dutchman
            Developer Most Active Administrators
            schrieb am zuletzt editiert von
            #22

            @nobse:

            Eigentlich reicht es wenn abgefragt wird ob der aktuelle Wert >= dem max wert ist und dann eine Benachrichtigung sendet oder? `

            Jup, erschien mir nur praktisch die Variable zB aus vis oder anderen scripten ändern zu können.

            –-----------------------

            Send from mobile device

            1 Antwort Letzte Antwort
            0
            • N Offline
              N Offline
              nobse
              schrieb am zuletzt editiert von
              #23

              OK habe das jetzt mal eingebaut

              • Script ruft sich nicht mehr selber alle xx Sekunden auf sondern über Function schedule

              • über writeLog kann Logeinträge Ein/Aus geschaltet werden

              • Datenpunkte xx_max werden angelegt und mit Werten gefüllt

              • aufruf Function isFehler prüft temp_ist >= temp-max und sendet Benachrichtigung (Fehlt noch)

              Was für Benachrichtigungen sind gewünscht?

              var server = "192.168.133.xx";
              var username = "x";
              var password = "x";
              var writeLog = false;
              
              var runs = 0;
              
              var instanz = 'javascript.' + instance;
              var pfad = '.iLO.';
              
              var request = require('request');
              
              function ilo(url, next, log){
                 url = "https://"+server+url;
                 request.timeout = 60000;
                 request({
                    "timeout": request.timeout,
                    "rejectUnauthorized": false, 
                    "url": url, 
                    "method": "GET", 
                    "headers":
                    {
                       "Content-Type": "application/json",
                       "Accept": "application/json",
                       "Authorization": "BASIC " + new Buffer(username+":"+password).toString('base64')
                    }
                 }, function(err, response, body){
                    if (log) console.log("\n => "+url+" <=\n"+body+"\n");
                    if (err) console.log(err+": "+url);
                    else if (response.statusCode != 200) console.log(response.statusCode+": "+url);
                    else if (next) next(JSON.parse(body));
                 });
              }
              
              function now() { return new Date().toISOString().replace(/T/, ' ').replace(/\..+/, ''); }
              
              function ping(){
                 ilo("/rest/v1/Chassis/1/Thermal", function(body){
                    var date = new Date();
                    var log = now();
                    if (runs++ == 0)      {
                       for (var f in body.Fans) {
                           var fan = body.Fans[f];
                           log += ", "+fan.FanName+" ["+fan.Units+"]";
                           createState(instanz + pfad + fan.FanName.replace(/ /g, '_'), {
                              name: fan.PhysicalContext, 
                              desc: fan.PhysicalContext,
                              type: 'number', 
                              def:  0,
                              read: true,
                              write: true,
                              role: 'value'  
                          }); 
              
                       }
                       for (var t in body.Temperatures) { var temp = body.Temperatures[t]; log += ", "+temp.Name+" ["+temp.Units+"]"; 
                          createState(instanz + pfad + temp.Name.replace(/ /g, '_'), {
                              name: temp.PhysicalContext, 
                              desc: temp.PhysicalContext,
                              type: 'number', 
                              def:  0,
                              read: true,
                              write: true,
                              role: 'value'  
                          });  
              
                          createState(instanz + pfad + temp.Name.replace(/ /g, '_') + "_max", {
                              name: temp.PhysicalContext + "_max", 
                              desc: temp.PhysicalContext + "_max",
                              type: 'number', 
                              def:  temp.LowerThresholdNonCritical,
                              read: true,
                              write: true,
                              role: 'value'  
                          });  
              
                       }
                       if (writeLog === true){
                           console.log(log);
                          log = now();
                       }
                    }
              
                      for (var f in body.Fans) {
                        var fan = body.Fans[f];
                        log += ", "+fan.CurrentReading;
                        setState(instanz + pfad + fan.FanName.replace(/ /g, '_'), fan.CurrentReading);
                      }
                      for (var t in body.Temperatures) {
                        var temp = body.Temperatures[t];
                        log += ", "+temp.CurrentReading;
                        setState(instanz + pfad + temp.Name.replace(/ /g, '_'), temp.CurrentReading);
                        isFehler(getState(instanz + pfad + temp.Name.replace(/ /g, '_') + "_max"),temp.CurrentReading)
                      }
              
                      if (writeLog === true){
                          console.log(log);
                      }
                 }, !true);
              }
              
              function isFehler(temp_max,temp_aktuell){
                  if (temp_aktuell >= temp_max){
                      console.log("max = " + temp_max.val);
                      console.log("ist = " + temp_aktuelle);
                      //Benachrichtigung Einbauen
                  }
              }
              
              //Script läuft alle 2 Minuten
              schedule("*/2 * * * *", function () {
                  console.log("===> Start ILO");
                  ping();
              });
              ping();
              

              Gruß Norbert

              CCU2 • Raspberry für Wetterstation • CMS http://www.exv2.de • HP ProLiant MicroServer Gen8 12GB RAM, 2x3TB, Windows Essentials Server 2016 mit ioBroker

              1 Antwort Letzte Antwort
              0
              • kmxakK Offline
                kmxakK Offline
                kmxak
                Most Active
                schrieb am zuletzt editiert von
                #24

                naja nun geht es ja schon richtung adapter.

                Zur Auswahl stehen bei mir. Als ersten Telegram (da sehr schnell die info kommt) oder email aber die schaut man ja auch nicht immer nach.

                Für die Leute die den z.B HP Gen 8 mit einem anderen CPU ausgestattet haben gehen aber die ausgelesenen Temp werte nicht oder? Oder werden die beim CPU wechsel auch im iLO aktualisiert?

                Außer CPU brauche ich keine Max Werte ändern.

                Die Warnung möchte ich allerding schon haben bevor die Max Temp erreicht wird. Quasi Grün er Bereich dann Oragnener mit Warnung und Rot mit ggf Shutdown später o.ä.

                In den History Adapter werde ich ihn auf jeden fall auch einfügen dann kann ich mir das mal genauer ansehen.

                Leider steht der Server bei mir unter dem Dachboden :cry: Ich habe bestimmt 26° aktuell hier …. und es nicht mal richtig sommer

                Gruß Alex

                1 Antwort Letzte Antwort
                0
                • N Offline
                  N Offline
                  nobse
                  schrieb am zuletzt editiert von
                  #25

                  So habe mal die Mailbenachrichtigung eingebaut.

                  Kann einer von euch mal den Code für Telegramm einbauen. Ich habe so was nicht. Kommt in die Function isFehler in die entsprechende If abfrage.

                  var server = "192.168.133.x";
                  var username = "x";
                  var password = "x";
                  var emailadresse = "x";  //E-Mailadresse für Benachrichtigung
                  
                  var writeLog = false;
                  var benachrichtigung_per_email = false;
                  var benachrichtigung_per_telegramm = false
                  
                  var runs = 0;
                  
                  var instanz = 'javascript.' + instance;
                  var pfad = '.iLO.';
                  
                  var request = require('request');
                  
                  function ilo(url, next, log){
                     url = "https://"+server+url;
                     request.timeout = 60000;
                     request({
                        "timeout": request.timeout,
                        "rejectUnauthorized": false, 
                        "url": url, 
                        "method": "GET", 
                        "headers":
                        {
                           "Content-Type": "application/json",
                           "Accept": "application/json",
                           "Authorization": "BASIC " + new Buffer(username+":"+password).toString('base64')
                        }
                     }, function(err, response, body){
                        if (log) console.log("\n => "+url+" <=\n"+body+"\n");
                        if (err) console.log(err+": "+url);
                        else if (response.statusCode != 200) console.log(response.statusCode+": "+url);
                        else if (next) next(JSON.parse(body));
                     });
                  }
                  
                  function now() { return new Date().toISOString().replace(/T/, ' ').replace(/\..+/, ''); }
                  
                  function ping(){
                     ilo("/rest/v1/Chassis/1/Thermal", function(body){
                        var date = new Date();
                        var log = now();
                        if (runs++ === 0)      {
                            createState(instanz + pfad + "iLO_Status", {
                                  name: "iLO_Status", 
                                  desc: "iLO_Status Gesamt",
                                  type: 'boolean', 
                                  def:  false,
                                  read: true,
                                  write: true,
                                  role: ''
                              }); 
                  
                           for (var f in body.Fans) {
                               var fan = body.Fans[f];
                               log += ", "+fan.FanName+" ["+fan.Units+"]";
                               createState(instanz + pfad + fan.FanName.replace(/ /g, '_'), {
                                  name: fan.PhysicalContext, 
                                  desc: fan.PhysicalContext,
                                  type: 'number', 
                                  def:  0,
                                  read: true,
                                  write: true,
                                  role: 'value'  
                              }); 
                  
                           }
                           for (var t in body.Temperatures) { var temp = body.Temperatures[t]; log += ", "+temp.Name+" ["+temp.Units+"]"; 
                              createState(instanz + pfad + temp.Name.replace(/ /g, '_'), {
                                  name: temp.PhysicalContext, 
                                  desc: temp.PhysicalContext,
                                  type: 'number', 
                                  def:  0,
                                  read: true,
                                  write: true,
                                  role: 'value'  
                              });  
                  
                              createState(instanz + pfad + temp.Name.replace(/ /g, '_') + "_max", {
                                  name: temp.PhysicalContext + "_max", 
                                  desc: temp.PhysicalContext + "_max",
                                  type: 'number', 
                                  def:  temp.LowerThresholdNonCritical,
                                  read: true,
                                  write: true,
                                  role: 'value'  
                              });  
                  
                          }
                          if (writeLog === true){
                              console.log(log);
                              log = now();
                          }
                        }
                  
                          for (var f in body.Fans) {
                              var fan = body.Fans[f];
                              log += ", "+fan.CurrentReading;
                              setState(instanz + pfad + fan.FanName.replace(/ /g, '_'), fan.CurrentReading);
                          }
                  
                          for (var t in body.Temperatures) {
                              var temp = body.Temperatures[t];
                              log += ", "+temp.CurrentReading;
                              setState(instanz + pfad + temp.Name.replace(/ /g, '_'), temp.CurrentReading);
                              isFehler(temp);
                          }
                  
                          if (writeLog === true){
                              console.log(log);
                          }
                      }, !true);
                  }
                  
                  function isFehler(temp){
                  
                      var max = getState(instanz + pfad + temp.Name.replace(/ /g, '_') + "_max");
                      var aktuell = temp.CurrentReading;
                      if (aktuell >= max){
                  
                          setState(instanz + pfad + "iLO_Status", true);
                  
                          if (benachrichtigung_per_email === true){
                              sendTo("email", {
                                  to:      emailadresse,
                                  subject: "Temperatur Warnung!!",
                                  text:    "Aktuelle Temperatur " + temp.Name + " = " + aktuell + " Grad Celsius."
                              });
                          }
                  
                          if (benachrichtigung_per_telegramm === true){
                  
                          } 
                      }
                  }
                  
                  //Script läuft alle 2 Minuten
                  schedule("*/2 * * * *", function () {
                      console.log("===> Start ILO");
                      ping();
                  });
                  

                  Gruß Norbert

                  CCU2 • Raspberry für Wetterstation • CMS http://www.exv2.de • HP ProLiant MicroServer Gen8 12GB RAM, 2x3TB, Windows Essentials Server 2016 mit ioBroker

                  1 Antwort Letzte Antwort
                  0
                  • kmxakK Offline
                    kmxakK Offline
                    kmxak
                    Most Active
                    schrieb am zuletzt editiert von
                    #26

                    Hier mal ein Script was funktionieren sollte mit Telegram:

                    Leider bekomme ich weder in Telegram noch per Mail was.

                    Ich habe nun 2 Max Werte auf 10° gesetzt das sollte doch dann sofort die Benachrichtigung auslösen oder?

                    Lösen die nicht installieten Temp Fühler mit Wert 0 und Max 0 auch die Benachrichtigung aus?

                    var server = "192.168.133.x";
                    var username = "x";
                    var password = "x";
                    var emailadresse = "x";  //E-Mailadresse für Benachrichtigung
                    var writeLog = true;
                    var benachrichtigung_per_email = true;
                    var benachrichtigung_per_telegramm = true; // hier hattest du kein ; das war falsch oder?
                    
                    var runs = 0;
                    
                    var instanz = 'javascript.' + instance;
                    var pfad = '.iLO.';
                    
                    var request = require('request');
                    
                    function ilo(url, next, log){
                       url = "https://"+server+url;
                       request.timeout = 60000;
                       request({
                          "timeout": request.timeout,
                          "rejectUnauthorized": false, 
                          "url": url, 
                          "method": "GET", 
                          "headers":
                          {
                             "Content-Type": "application/json",
                             "Accept": "application/json",
                             "Authorization": "BASIC " + new Buffer(username+":"+password).toString('base64')
                          }
                       }, function(err, response, body){
                          if (log) console.log("\n => "+url+" <=\n"+body+"\n");
                          if (err) console.log(err+": "+url);
                          else if (response.statusCode != 200) console.log(response.statusCode+": "+url);
                          else if (next) next(JSON.parse(body));
                       });
                    }
                    
                    function now() { return new Date().toISOString().replace(/T/, ' ').replace(/\..+/, ''); }
                    
                    function ping(){
                       ilo("/rest/v1/Chassis/1/Thermal", function(body){
                          var date = new Date();
                          var log = now();
                          if (runs++ === 0)      {
                              createState(instanz + pfad + "iLO_Status", {
                                    name: "iLO_Status", 
                                    desc: "iLO_Status Gesamt",
                                    type: 'boolean', 
                                    def:  false,
                                    read: true,
                                    write: true,
                                    role: ''
                                }); 
                    
                             for (var f in body.Fans) {
                                 var fan = body.Fans[f];
                                 log += ", "+fan.FanName+" ["+fan.Units+"]";
                                 createState(instanz + pfad + fan.FanName.replace(/ /g, '_'), {
                                    name: fan.PhysicalContext, 
                                    desc: fan.PhysicalContext,
                                    type: 'number', 
                                    def:  0,
                                    read: true,
                                    write: true,
                                    role: 'value'  
                                }); 
                    
                             }
                             for (var t in body.Temperatures) { var temp = body.Temperatures[t]; log += ", "+temp.Name+" ["+temp.Units+"]"; 
                                createState(instanz + pfad + temp.Name.replace(/ /g, '_'), {
                                    name: temp.PhysicalContext, 
                                    desc: temp.PhysicalContext,
                                    type: 'number', 
                                    def:  0,
                                    read: true,
                                    write: true,
                                    role: 'value'  
                                });  
                    
                                createState(instanz + pfad + temp.Name.replace(/ /g, '_') + "_max", {
                                    name: temp.PhysicalContext + "_max", 
                                    desc: temp.PhysicalContext + "_max",
                                    type: 'number', 
                                    def:  temp.LowerThresholdNonCritical,
                                    read: true,
                                    write: true,
                                    role: 'value'  
                                });  
                    
                            }
                            if (writeLog === true){
                                console.log(log);
                                log = now();
                            }
                          }
                    
                            for (var f in body.Fans) {
                                var fan = body.Fans[f];
                                log += ", "+fan.CurrentReading;
                                setState(instanz + pfad + fan.FanName.replace(/ /g, '_'), fan.CurrentReading);
                            }
                    
                            for (var t in body.Temperatures) {
                                var temp = body.Temperatures[t];
                                log += ", "+temp.CurrentReading;
                                setState(instanz + pfad + temp.Name.replace(/ /g, '_'), temp.CurrentReading);
                                isFehler(temp);
                            }
                    
                            if (writeLog === true){
                                console.log(log);
                            }
                        }, !true);
                    }
                    
                    function isFehler(temp){
                    
                        var max = getState(instanz + pfad + temp.Name.replace(/ /g, '_') + "_max");
                        var aktuell = temp.CurrentReading;
                        if (aktuell >= max){
                    
                            setState(instanz + pfad + "iLO_Status", true);
                    
                            if (benachrichtigung_per_email === true){
                                sendTo("email", {
                                    to:      emailadresse,
                                    subject: "Temperatur Warnung!!",
                                    text:    "Aktuelle Temperatur " + temp.Name + " = " + aktuell + " Grad Celsius."
                                });
                            }
                    
                            if (benachrichtigung_per_telegramm === true){
                               sendTo("telegram.0", "send", {
                                   text:    "Aktuelle Temperatur " + temp.Name + " = " + aktuell + " Grad Celsius."  // um die Nachricht nur an Teilnehme xy zu schicken folgendes anfügen , chatId: 'xxx'
                                });
                            } 
                        }
                    }
                    
                    //Script läuft alle 2 Minuten
                    schedule("*/2 * * * *", function () {
                        console.log("===> Start ILO");
                        ping();
                    });
                    

                    Gruß Alex

                    1 Antwort Letzte Antwort
                    0
                    • N Offline
                      N Offline
                      nobse
                      schrieb am zuletzt editiert von
                      #27

                      Ah ja da gebe ich dir recht das es nicht geht.

                      Andere mal die Zeile

                      if (aktuell >= max){
                      

                      in

                      if (aktuell > max.val){
                      

                      Gruß Norbert

                      CCU2 • Raspberry für Wetterstation • CMS http://www.exv2.de • HP ProLiant MicroServer Gen8 12GB RAM, 2x3TB, Windows Essentials Server 2016 mit ioBroker

                      1 Antwort Letzte Antwort
                      0
                      • kmxakK Offline
                        kmxakK Offline
                        kmxak
                        Most Active
                        schrieb am zuletzt editiert von
                        #28

                        Jawohl es geht!

                        Nochmal den Text etwas angepasst.

                        Er sendet nun aber alle 2 Minuten eine Benachrichtigung solange die Temperatur zu hoch ist.

                        Kann man das irgendwie nur einmal machen? Sonst wirst du voll gespammt 8-)

                        var server = "192.168.133.x";
                        var username = "x";
                        var password = "x";
                        var emailadresse = "x";  //E-Mailadresse für Benachrichtigungvar writeLog = true;
                        var benachrichtigung_per_email = false;
                        var benachrichtigung_per_telegramm = true; // hier hattest du kein ; das war falsch oder?
                        
                        var runs = 0;
                        
                        var instanz = 'javascript.' + instance;
                        var pfad = '.iLO.';
                        
                        var request = require('request');
                        
                        function ilo(url, next, log){
                           url = "https://"+server+url;
                           request.timeout = 60000;
                           request({
                              "timeout": request.timeout,
                              "rejectUnauthorized": false, 
                              "url": url, 
                              "method": "GET", 
                              "headers":
                              {
                                 "Content-Type": "application/json",
                                 "Accept": "application/json",
                                 "Authorization": "BASIC " + new Buffer(username+":"+password).toString('base64')
                              }
                           }, function(err, response, body){
                              if (log) console.log("\n => "+url+" <=\n"+body+"\n");
                              if (err) console.log(err+": "+url);
                              else if (response.statusCode != 200) console.log(response.statusCode+": "+url);
                              else if (next) next(JSON.parse(body));
                           });
                        }
                        
                        function now() { return new Date().toISOString().replace(/T/, ' ').replace(/\..+/, ''); }
                        
                        function ping(){
                           ilo("/rest/v1/Chassis/1/Thermal", function(body){
                              var date = new Date();
                              var log = now();
                              if (runs++ === 0)      {
                                  createState(instanz + pfad + "iLO_Status", {
                                        name: "iLO_Status", 
                                        desc: "iLO_Status Gesamt",
                                        type: 'boolean', 
                                        def:  false,
                                        read: true,
                                        write: true,
                                        role: ''
                                    }); 
                        
                                 for (var f in body.Fans) {
                                     var fan = body.Fans[f];
                                     log += ", "+fan.FanName+" ["+fan.Units+"]";
                                     createState(instanz + pfad + fan.FanName.replace(/ /g, '_'), {
                                        name: fan.PhysicalContext, 
                                        desc: fan.PhysicalContext,
                                        type: 'number', 
                                        def:  0,
                                        read: true,
                                        write: true,
                                        role: 'value'  
                                    }); 
                        
                                 }
                                 for (var t in body.Temperatures) { var temp = body.Temperatures[t]; log += ", "+temp.Name+" ["+temp.Units+"]"; 
                                    createState(instanz + pfad + temp.Name.replace(/ /g, '_'), {
                                        name: temp.PhysicalContext, 
                                        desc: temp.PhysicalContext,
                                        type: 'number', 
                                        def:  0,
                                        read: true,
                                        write: true,
                                        role: 'value'  
                                    });  
                        
                                    createState(instanz + pfad + temp.Name.replace(/ /g, '_') + "_max", {
                                        name: temp.PhysicalContext + "_max", 
                                        desc: temp.PhysicalContext + "_max",
                                        type: 'number', 
                                        def:  temp.LowerThresholdNonCritical,
                                        read: true,
                                        write: true,
                                        role: 'value'  
                                    });  
                        
                                }
                                if (writeLog === true){
                                    console.log(log);
                                    log = now();
                                }
                              }
                        
                                for (var f in body.Fans) {
                                    var fan = body.Fans[f];
                                    log += ", "+fan.CurrentReading;
                                    setState(instanz + pfad + fan.FanName.replace(/ /g, '_'), fan.CurrentReading);
                                }
                        
                                for (var t in body.Temperatures) {
                                    var temp = body.Temperatures[t];
                                    log += ", "+temp.CurrentReading;
                                    setState(instanz + pfad + temp.Name.replace(/ /g, '_'), temp.CurrentReading);
                                    isFehler(temp);
                                }
                        
                                if (writeLog === true){
                                    console.log(log);
                                }
                            }, !true);
                        }
                        
                        function isFehler(temp){
                        
                            var max = getState(instanz + pfad + temp.Name.replace(/ /g, '_') + "_max");
                            var aktuell = temp.CurrentReading;
                            if (aktuell > max.val){
                        
                                setState(instanz + pfad + "iLO_Status", true);
                        
                                if (benachrichtigung_per_email === true){
                                    sendTo("email", {
                                        to:      emailadresse,
                                        subject: "Temperatur Warnung!!",
                                        text:    "Aktuelle Temperatur " + temp.Name + " = " + aktuell + " Grad Celsius."
                                    });
                                }
                        
                                if (benachrichtigung_per_telegramm === true){
                                   sendTo("telegram.1", "send", {
                                       text:    "iLO Temperatur Warnung!! Aktuelle Temperatur " + temp.Name + " = " + aktuell + " Grad Celsius."  // um die Nachricht nur an Teilnehme xy zu schicken folgendes anfügen , chatId: 'xxx'
                                    });
                                } 
                            }
                        }
                        
                        //Script läuft alle 2 Minuten
                        schedule("*/2 * * * *", function () {
                            console.log("===> Start ILO");
                            ping();
                        });
                        

                        Gruß Alex

                        1 Antwort Letzte Antwort
                        0
                        • kmxakK Offline
                          kmxakK Offline
                          kmxak
                          Most Active
                          schrieb am zuletzt editiert von
                          #29

                          was ich gerade noch nicht kapiere ist der iLO status.. der wurde ja auf true gesetzt wegen meiner max temp auf 10 gestellt.

                          Habe dann die Temperaturwerte Max gelöscht und neu erstellen lassen aber ich habe immer noch die selben warnungen erhalten. Auch ein Script neustart änderte nix.

                          Habe den iLO status dann manuell auf false gesetzt nun ist alles wieder ruhig.

                          Passt da was noch nicht?

                          Gruß Alex

                          1 Antwort Letzte Antwort
                          0
                          • N Offline
                            N Offline
                            nobse
                            schrieb am zuletzt editiert von
                            #30
                            • Benachrichtigungen werden nur einmal gesendet

                            • iLO_Status wird bei Fehlern auf TRUE gesetzt und wenn keine Fehler auf FALSE

                            var server = "192.168.133.x";
                            var username = "x";
                            var password = "x";
                            var emailadresse = "x";  //E-Mailadresse für Benachrichtigung
                            
                            var writeLog = false;
                            var benachrichtigung_per_email = true;  //Mail Adapter muss installiert sein
                            var benachrichtigung_per_telegramm = false; //Telegram Adapter muss installiert sein
                            var benachrichtigung_gesendet = 0;
                            
                            var runs = 0;
                            var anzahl_fehler = 0;
                            
                            var instanz = 'javascript.' + instance;
                            var pfad = '.iLO.';
                            
                            var request = require('request');
                            
                            function ilo(url, next, log){
                               url = "https://"+server+url;
                               request.timeout = 60000;
                               request({
                                  "timeout": request.timeout,
                                  "rejectUnauthorized": false, 
                                  "url": url, 
                                  "method": "GET", 
                                  "headers":
                                  {
                                     "Content-Type": "application/json",
                                     "Accept": "application/json",
                                     "Authorization": "BASIC " + new Buffer(username+":"+password).toString('base64')
                                  }
                               }, function(err, response, body){
                                  if (log) console.log("\n => "+url+" <=\n"+body+"\n");
                                  if (err) console.log(err+": "+url);
                                  else if (response.statusCode != 200) console.log(response.statusCode+": "+url);
                                  else if (next) next(JSON.parse(body));
                               });
                            }
                            
                            function now() { return new Date().toISOString().replace(/T/, ' ').replace(/\..+/, ''); }
                            
                            function ping(){
                               ilo("/rest/v1/Chassis/1/Thermal", function(body){
                                  var date = new Date();
                                  var log = now();
                                  if (runs++ === 0)      {
                                      createState(instanz + pfad + "iLO_Status", {
                                            name: "iLO_Status", 
                                            desc: "iLO_Status Gesamt",
                                            type: 'boolean', 
                                            def:  false,
                                            read: true,
                                            write: true,
                                            role: ''
                            
                                        }); 
                                     for (var f in body.Fans) {
                                         var fan = body.Fans[f];
                                         log += ", "+fan.FanName+" ["+fan.Units+"]";
                                         createState(instanz + pfad + fan.FanName.replace(/ /g, '_'), {
                                            name: fan.PhysicalContext, 
                                            desc: fan.PhysicalContext,
                                            type: 'number', 
                                            def:  0,
                                            read: true,
                                            write: true,
                                            role: 'value'  
                                        }); 
                            
                                     }
                                     for (var t in body.Temperatures) { var temp = body.Temperatures[t]; log += ", "+temp.Name+" ["+temp.Units+"]"; 
                                        createState(instanz + pfad + temp.Name.replace(/ /g, '_'), {
                                            name: temp.PhysicalContext, 
                                            desc: temp.PhysicalContext,
                                            type: 'number', 
                                            def:  0,
                                            read: true,
                                            write: true,
                                            role: 'value'  
                                        });  
                            
                                        createState(instanz + pfad + temp.Name.replace(/ /g, '_') + "_max", {
                                            name: temp.PhysicalContext + "_max", 
                                            desc: temp.PhysicalContext + "_max",
                                            type: 'number', 
                                            def:  temp.LowerThresholdNonCritical,
                                            read: true,
                                            write: true,
                                            role: 'value'  
                                        });  
                                    }
                                    if (writeLog === true){
                                        console.log(log);
                                        log = now();
                                    }
                                  }
                                  anzahl_fehler = 0;
                                    for (var f in body.Fans) {
                                        var fan = body.Fans[f];
                                        log += ", "+fan.CurrentReading;
                                        setState(instanz + pfad + fan.FanName.replace(/ /g, '_'), fan.CurrentReading);
                                    }
                            
                                    for (var t in body.Temperatures) {
                                        var temp = body.Temperatures[t];
                                        log += ", "+temp.CurrentReading;
                                        setState(instanz + pfad + temp.Name.replace(/ /g, '_'), temp.CurrentReading);
                                        isFehler(temp);
                                    }
                            
                                    if (anzahl_fehler > 0){
                                        setState(instanz + pfad + "iLO_Status", true);
                                    }else{
                                        setState(instanz + pfad + "iLO_Status", false);
                                        benachrichtigung_gesendet = 0;
                                    }
                            
                                    if (writeLog === true){
                                        console.log(log);
                                    }
                                }, !true);
                            }
                            
                            function isFehler(temp){
                            
                                var max = getState(instanz + pfad + temp.Name.replace(/ /g, '_') + "_max");
                                var aktuell = temp.CurrentReading;
                            
                                if (aktuell > max.val){
                                    anzahl_fehler++;
                                    if (benachrichtigung_per_email === true & benachrichtigung_gesendet === 0){
                                        sendTo("email", {
                                            to:      emailadresse,
                                            subject: "iLO Temperatur Warnung!!",
                                            text:    "Aktuelle Temperatur " + temp.Name + " = " + aktuell + " Grad Celsius."
                                        });
                                        benachrichtigung_gesendet = 1;
                                    }
                            
                                    if (benachrichtigung_per_telegramm === true & benachrichtigung_gesendet === 0){
                                        sendTo("telegram." + instance, "send", {
                                            text: ("iLO Temperatur Warnung!! Aktuelle Temperatur " + temp.Name + " = " + aktuell + " Grad Celsius.") // um die Nachricht nur an Teilnehme xy zu schicken folgendes anfügen , chatId: 'xxx'
                                        });
                                        benachrichtigung_gesendet = 1;
                                    } 
                                }
                            }
                            
                            //Script läuft alle 2 Minuten
                            schedule("*/2 * * * *", function () {
                                console.log("===> Start ILO");
                                ping();
                            });
                            

                            Gruß Norbert

                            CCU2 • Raspberry für Wetterstation • CMS http://www.exv2.de • HP ProLiant MicroServer Gen8 12GB RAM, 2x3TB, Windows Essentials Server 2016 mit ioBroker

                            1 Antwort Letzte Antwort
                            0
                            • kmxakK Offline
                              kmxakK Offline
                              kmxak
                              Most Active
                              schrieb am zuletzt editiert von
                              #31

                              ok mit dem script bekomme ich keine ausgabe vom ilo mehr

                              edit ok ausgabe geht wieder

                              er setzt den ilo status auf true aber es kommt keine benachrichtigung

                              edit 2:

                              muss das script ein neues objekt erstellen?

                              anzahl fehler oder sowas? unter objekten ist alles noch beim alten. Oder wird das alles intern im script gemacht?

                              Gruß Alex

                              1 Antwort Letzte Antwort
                              0
                              • N Offline
                                N Offline
                                nobse
                                schrieb am zuletzt editiert von
                                #32

                                Also

                                anzahl_fehler ist nur eine Variable im Script.

                                Habe gerade noch mal getestet

                                • 13-LOM_max auf 10 gesetzt

                                • beim nächsten Durchlauft wird iLO_Status auf true gesetzt und E-Mail versendet

                                • beim nächsten Durchlauf wird keine E-Mail versendet

                                • 13-LOM_max auf 100 gesetzt

                                • beim nächsten Durchlauf wird iLO_Status auf false gesetzt und keine E-Mail versendet

                                Gruß Norbert

                                CCU2 • Raspberry für Wetterstation • CMS http://www.exv2.de • HP ProLiant MicroServer Gen8 12GB RAM, 2x3TB, Windows Essentials Server 2016 mit ioBroker

                                1 Antwort Letzte Antwort
                                0
                                • kmxakK Offline
                                  kmxakK Offline
                                  kmxak
                                  Most Active
                                  schrieb am zuletzt editiert von
                                  #33
                                  javascript.0	2017-05-16 22:38:00.388	info	script.js.Test.iLO_Temp: ===> Start ILO
                                  javascript.0	2017-05-16 22:36:00.383	info	script.js.Test.iLO_Temp: ===> Start ILO
                                  

                                  schaltet den ilo status auf true aber es kommt nix.

                                  werte liest er auch schon wieder nicht aus.

                                  woran es gerade scheitert und warum es eben noch ging ist mir ein rätsel

                                  mein aktuelles script ohne ip user und pw

                                  das einzige was ich immer änder ist hinter var benachrichtigung_per_telegramm = true; das ; setzen und telegram. hier die instanz 1 setzen.

                                  var writeLog = false;
                                  var benachrichtigung_per_email = true;  //Mail Adapter muss installiert sein
                                  var benachrichtigung_per_telegramm = true; //Telegram Adapter muss installiert sein
                                  var benachrichtigung_gesendet = 0;
                                  
                                  var runs = 0;
                                  var anzahl_fehler = 0;
                                  
                                  var instanz = 'javascript.' + instance;
                                  var pfad = '.iLO.';
                                  
                                  var request = require('request');
                                  
                                  function ilo(url, next, log){
                                     url = "https://"+server+url;
                                     request.timeout = 60000;
                                     request({
                                        "timeout": request.timeout,
                                        "rejectUnauthorized": false, 
                                        "url": url, 
                                        "method": "GET", 
                                        "headers":
                                        {
                                           "Content-Type": "application/json",
                                           "Accept": "application/json",
                                           "Authorization": "BASIC " + new Buffer(username+":"+password).toString('base64')
                                        }
                                     }, function(err, response, body){
                                        if (log) console.log("\n => "+url+" <=\n"+body+"\n");
                                        if (err) console.log(err+": "+url);
                                        else if (response.statusCode != 200) console.log(response.statusCode+": "+url);
                                        else if (next) next(JSON.parse(body));
                                     });
                                  }
                                  
                                  function now() { return new Date().toISOString().replace(/T/, ' ').replace(/\..+/, ''); }
                                  
                                  function ping(){
                                     ilo("/rest/v1/Chassis/1/Thermal", function(body){
                                        var date = new Date();
                                        var log = now();
                                        if (runs++ === 0)      {
                                            createState(instanz + pfad + "iLO_Status", {
                                                  name: "iLO_Status", 
                                                  desc: "iLO_Status Gesamt",
                                                  type: 'boolean', 
                                                  def:  false,
                                                  read: true,
                                                  write: true,
                                                  role: ''
                                  
                                              }); 
                                           for (var f in body.Fans) {
                                               var fan = body.Fans[f];
                                               log += ", "+fan.FanName+" ["+fan.Units+"]";
                                               createState(instanz + pfad + fan.FanName.replace(/ /g, '_'), {
                                                  name: fan.PhysicalContext, 
                                                  desc: fan.PhysicalContext,
                                                  type: 'number', 
                                                  def:  0,
                                                  read: true,
                                                  write: true,
                                                  role: 'value'  
                                              }); 
                                  
                                           }
                                           for (var t in body.Temperatures) { var temp = body.Temperatures[t]; log += ", "+temp.Name+" ["+temp.Units+"]"; 
                                              createState(instanz + pfad + temp.Name.replace(/ /g, '_'), {
                                                  name: temp.PhysicalContext, 
                                                  desc: temp.PhysicalContext,
                                                  type: 'number', 
                                                  def:  0,
                                                  read: true,
                                                  write: true,
                                                  role: 'value'  
                                              });  
                                  
                                              createState(instanz + pfad + temp.Name.replace(/ /g, '_') + "_max", {
                                                  name: temp.PhysicalContext + "_max", 
                                                  desc: temp.PhysicalContext + "_max",
                                                  type: 'number', 
                                                  def:  temp.LowerThresholdNonCritical,
                                                  read: true,
                                                  write: true,
                                                  role: 'value'  
                                              });  
                                          }
                                          if (writeLog === true){
                                              console.log(log);
                                              log = now();
                                          }
                                        }
                                        anzahl_fehler = 0;
                                          for (var f in body.Fans) {
                                              var fan = body.Fans[f];
                                              log += ", "+fan.CurrentReading;
                                              setState(instanz + pfad + fan.FanName.replace(/ /g, '_'), fan.CurrentReading);
                                          }
                                  
                                          for (var t in body.Temperatures) {
                                              var temp = body.Temperatures[t];
                                              log += ", "+temp.CurrentReading;
                                              setState(instanz + pfad + temp.Name.replace(/ /g, '_'), temp.CurrentReading);
                                              isFehler(temp);
                                          }
                                  
                                          if (anzahl_fehler > 0){
                                              setState(instanz + pfad + "iLO_Status", true);
                                          }else{
                                              setState(instanz + pfad + "iLO_Status", false);
                                              benachrichtigung_gesendet = 0;
                                          }
                                  
                                          if (writeLog === true){
                                              console.log(log);
                                          }
                                      }, !true);
                                  }
                                  
                                  function isFehler(temp){
                                  
                                      var max = getState(instanz + pfad + temp.Name.replace(/ /g, '_') + "_max");
                                      var aktuell = temp.CurrentReading;
                                  
                                      if (aktuell > max.val){
                                          anzahl_fehler++;
                                          if (benachrichtigung_per_email === true & benachrichtigung_gesendet === 0){
                                              sendTo("email", {
                                                  to:      emailadresse,
                                                  subject: "iLO Temperatur Warnung!!",
                                                  text:    "Aktuelle Temperatur " + temp.Name + " = " + aktuell + " Grad Celsius."
                                              });
                                              benachrichtigung_gesendet = 1;
                                          }
                                  
                                          if (benachrichtigung_per_telegramm === true & benachrichtigung_gesendet === 0){
                                              sendTo("telegram.1" + instance, "send", {
                                                  text: ("iLO Temperatur Warnung!! Aktuelle Temperatur " + temp.Name + " = " + aktuell + " Grad Celsius.") // um die Nachricht nur an Teilnehme xy zu schicken folgendes anfügen , chatId: 'xxx'
                                              });
                                              benachrichtigung_gesendet = 1;
                                          } 
                                      }
                                  }
                                  
                                  //Script läuft alle 2 Minuten
                                  schedule("*/2 * * * *", function () {
                                      console.log("===> Start ILO");
                                      ping();
                                  });
                                  

                                  Gruß Alex

                                  1 Antwort Letzte Antwort
                                  0
                                  • N Offline
                                    N Offline
                                    nobse
                                    schrieb am zuletzt editiert von
                                    #34

                                    Nehme mal bitte das 1 bei telegram weg oder lösche das + instance

                                    Gruß Norbert

                                    CCU2 • Raspberry für Wetterstation • CMS http://www.exv2.de • HP ProLiant MicroServer Gen8 12GB RAM, 2x3TB, Windows Essentials Server 2016 mit ioBroker

                                    1 Antwort Letzte Antwort
                                    0
                                    • kmxakK Offline
                                      kmxakK Offline
                                      kmxak
                                      Most Active
                                      schrieb am zuletzt editiert von
                                      #35

                                      Jo das war es

                                      es muss so sein

                                      sendTo("telegram.1", "send", {
                                      

                                      jedenfalls bei mir weil ich es auf instanz 1 haben möchte.

                                      Hatte nicht gesehen das du da was geändert hattest ;)

                                      Gruß Alex

                                      1 Antwort Letzte Antwort
                                      0
                                      • N Offline
                                        N Offline
                                        nobse
                                        schrieb am zuletzt editiert von
                                        #36

                                        Was hast du eigentlich für eine CPU in deinem GEN8? Ich habe einen Intel(R) Celeron(R) CPU G1610T @ 2.30GHz und suche was schnelleres was auf das Board past. Hast du da eine Idee?

                                        Für heute ist für mich Feierabend.

                                        Gruß Norbert

                                        CCU2 • Raspberry für Wetterstation • CMS http://www.exv2.de • HP ProLiant MicroServer Gen8 12GB RAM, 2x3TB, Windows Essentials Server 2016 mit ioBroker

                                        1 Antwort Letzte Antwort
                                        0
                                        • kmxakK Offline
                                          kmxakK Offline
                                          kmxak
                                          Most Active
                                          schrieb am zuletzt editiert von
                                          #37

                                          Ich habe auch noch Ideal Standart.

                                          Habe mehrere in Ebay auf beobachtungsliste 150-250€ aber momentan ist mir das zu teuer. Der CPU bei mir ist noch nicht ausgelastet. ( Erschwerend bei mir auch das Temperaturproblem unter dem Dachboden)

                                          Die TDP der meisten CPU's sind ja bei 70 oder da drüber…

                                          Der Intel Xeon E3-1265L v2 hat eine TPD von 45W da würde der OEM CPU Kühler fast noch reichen. Läuft ja auch nicht immer unter Volllast.

                                          Kannst ja mal hier schauen:

                                          https://www.hardwareluxx.de/community/f ... 63207.html

                                          Gruß Alex

                                          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

                                          806

                                          Online

                                          32.6k

                                          Benutzer

                                          82.1k

                                          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