NEWS
[Frage] ioBroker - iLO Server Daten auslesen
-
Moin,
hier geht es um ein Script für HP iLO. Mit dem Script ist es möglich die Temperaturwerte im Server sowie den CPU Lüfter in ioBroker einzubinden.
Das Script müsste ab iLO 2 lauffähig sein.
getestet habe ich es mit iLO 4 FW 2.53
Hardware war ein Hp Gen8 Server
Sicherheitsinfo!
Bitte erstellt für das Script einen neuen Benutzer ohne Rechte. (ggf nur Login Rechte)
Hier immer das aktuellste lauffähige Script:
var server = "192.168.2.x"; var username = "xxx"; var password = "xxx"; var emailadresse = "x@x.x"; //E-Mailadresse für Benachrichtigung var writeLog = true; var benachrichtigung_per_email = false; //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.0", "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(); });
-
Hallo kmxak
habe mir dein Script kopiert und die IP Adresse, Benutzer und Passwort angepast. Dann gestartet und läuft super und beringt genau die erwartet Ergebnisse
11:26:29.258 [info] javascript.0 script.js.ILO: 2017-05-15 09:26:29, Fan 1 [Percent], 01-Inlet Ambient [Celsius], 02-CPU [Celsius], 03-P1 DIMM 1-2 [Celsius], 04-HD Max [Celsius], 05-Chipset [Celsius], 06-Chipset Zone [Celsius], 07-VR P1 Zone [Celsius], 08-Supercap Max [Celsius], 09-iLO Zone [Celsius], 10-PCI 1 [Celsius], 11-PCI 1 Zone [Celsius], 12-Sys Exhaust [Celsius], 13-LOM [Celsius] 11:26:29.258 [info] javascript.0 script.js.ILO: 2017-05-15 09:26:29, 7, 24, 40, 37, 36, 63, 48, 51, 0, 49, 0, 42, 48, 65
Bekommst du auch keine Fehlermeldung?
-
Nein leider gar nichts.. Welche ilo Version nutzt du?
Gesendet von meinem SM-G928F mit Tapatalk
-
Ich habe die
iLO Firmware Version 2.50 Sep 23 2016
ILO ist bei mir der Scriptname
Das sollte aber schon im Log stehen
javascript.0 2017-05-15 13:02:59.368 info Start javascript script.js.ILO
Trage mal eine falsche IP Adresse ein dann sollte folgendes im Log stehen
javascript.0 2017-05-15 13:03:41.264 info Stop script script.js.ILO javascript.0 2017-05-15 13:02:59.384 info script.js.ILO: Error: read ECONNRESET: https://192.168.xxx.xxx/rest/v1/Chassis/1/Thermal javascript.0 2017-05-15 13:02:59.368 info script.js.ILO: registered 0 subscriptions and 0 schedules javascript.0 2017-05-15 13:02:59.368 info Start javascript script.js.ILO
-
Ok werde nachher mal testen. Hast es im iobroker laufen lassen oder einfach so im Terminal? Hab die selbe ilo glaube ich sollte die aktuellste sein. Muss wohl an mir aktuell liegen. Muss ich nur die Daten noch in iobroker rein bekommen
Gesendet von meinem SM-G928F mit Tapatalk
-
Ja habe das im ioBroker getestet.
Habe einfach unter Scripte ein neues Script angelegt und Code reinkopiert und gestartet.
-
Jawoll so geht es nun auch bei mir.
Was nun noch ansteht ist für die Werte Datenpunkte in ioBroker anzulegen.
Dazu müsste das Script angepasst werden. Dort werde ich aber noch Hilfe brauchen.
Ich habe schon mal etwas gebastelt. Vielleicht kann da ja mal einer der sich gut mit programmieren auskennt drüber schauen und sagen ob ich das erste schon mal in die richtige richtung gemacht habe. :lol:
Bei dem Teil wo die Werte ausgelesen werden brauche ich definitiv hilfe. Keine Ahnung wie ich das umschreibe das er die Werte in die Objekte schreibt.
Hier der Code:
! ````
/*
iLO Daten auslesen
*/
var server = "192.168.x.x";
var username = "x";
var password = "x";
var pfad = '.iLO.';
var logging = false;
var secs = 30;
! var instanz = 'javascript.' + instance;
if (logging) log(instanz);
! var request = require('request');
! // ID definieren
var idFan = instanz + pfad + 'CPUFan',
id01 = instanz + pfad + 'InletAmbient',
id02 = instanz + pfad + 'CPU',
id03 = instanz + pfad + 'P1DIMM1-2',
id04 = instanz + pfad + 'HDMax',
id05 = instanz + pfad + 'Chipset',
id06 = instanz + pfad + 'ChipsetZone ',
id07 = instanz + pfad + 'VRP1Zone',
id08 = instanz + pfad + 'SupercapMax',
id09 = instanz + pfad + 'iLOZone ',
id10 = instanz + pfad + 'PCI1',
id11 = instanz + pfad + 'PCI1Zone',
id12 = instanz + pfad + 'SysExhaust',
id13 = instanz + pfad + 'LOM',// States erstellen
createState(idFan, {
name: 'CPU Lüfter',
desc: 'CPU Lüfter',
type: 'number',
def: 0,
read: true,
write: true,
role: 'value' // value richtig bei prozentzahl?
});
createState(id01, {
name: 'Inlet Ambient',
desc: 'Gehäusetemperatur vorne',
type: 'number',
def: 0,
read: true,
write: true,
role: 'value'
});
createState(id02, {
name: 'CPU Temperatur',
desc: 'CPU Temperatur',
type: 'number',
def: 0,
read: true,
write: true,
role: 'value'
});
createState(id03, {
name: 'P1 DIMM 1-2 ',
desc: 'Memory Ram Speicher Temperatur',
type: 'number',
def: 0,
read: true,
write: true,
role: 'value'
});
createState(id04, {
name: 'HD Max / Nicht installiert', // müsste Festplatte sein?!
desc: '',
type: 'number',
def: 0,
read: true,
write: true,
role: 'value'
});
createState(id05, {
name: 'Chipset',
desc: 'Chipsatz Temperatur',
type: 'number',
def: 0,
read: true,
write: true,
role: 'value'
});
createState(id06, {
name: 'Chipset Zone',
desc: 'Chipsatz Zonen Temperatur',
type: 'number',
def: 0,
read: true,
write: true,
role: 'value'
});
createState(id07, {
name: 'VR P1 Zone', // unbekannter Temperaturmesser
desc: '',
type: 'number',
def: 0,
read: true,
write: true,
role: 'value'
});
createState(id08, {
name: 'Supercap Max', // unbekannter Temperaturmesser
desc: '',
type: 'number',
def: 0,
read: true,
write: true,
role: 'value'
});
createState(id09, {
name: 'iLO Zone',
desc: 'iLO Chipsatz Temperatur',
type: 'number',
def: 0,
read: true,
write: true,
role: 'value'
});
createState(id10, {
name: 'PCI 1 ',
desc: 'PCI 1 Karten Temperatur',
type: 'number',
def: 0,
read: true,
write: true,
role: 'value'
});
createState(id11, {
name: 'PCI 1 Zone',
desc: 'PCI Slot Umgebungstemperatur',
type: 'number',
def: 0,
read: true,
write: true,
role: 'value'
});
createState(id12, {
name: 'Sys Exhaust',
desc: 'Gehäuse Temperatur hinten',
type: 'number',
def: 0,
read: true,
write: true,
role: 'value'
});
createState(id13, {
name: 'LOM', // unbekannter Temperaturmesser
desc: '',
type: 'number',
def: 0,
read: true,
write: true,
role: 'value'
});! // ab hier nicht weiter gemacht, Script müsste angepasst werden
! 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));
});
}
! var time = new Date().getTime();
function currentMS() { return (new Date().getTime()-time); }
function now() { return new Date().toISOString().replace(/T/, ' ').replace(/..+/, ''); }
! var runs = 0;
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+"]"; }
for (var t in body.Temperatures) { var temp = body.Temperatures[t]; log += ", "+temp.Name+" ["+temp.Units+"]"; }
console.log(log);
log = now();
}
for (var f in body.Fans) { var fan = body.Fans[f]; log += ", "+fan.CurrentReading; }
for (var t in body.Temperatures) { var temp = body.Temperatures[t]; log += ", "+temp.CurrentReading; }
console.log(log);
setTimeout(function(){ping();}, secs*1000);
}, !true);
}
! ping();Einen Error macht das Script noch bei mir:
javascript.0 script.js.Test.iLO: Error: ETIMEDOUT: https://192.168.178.8/rest/v1/Chassis/1/Thermal
Edit: Datenpunkte legt er noch nicht an… irgendein Fehler... :(
-
Habe das jetzt mal so gelöst.
Variablen werden erstellt und mit entsprechenden werten gefüll
var server = "192.168.133.x"; var username = "xx"; var password = "xx"; var secs = 30; 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)); }); } var time = new Date().getTime(); function currentMS() { return (new Date().getTime()-time); } function now() { return new Date().toISOString().replace(/T/, ' ').replace(/\..+/, ''); } var runs = 0; 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' }); } 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); } console.log(log); setTimeout(function(){ping();}, secs*1000); }, !true); } ping();
Deine Fehlermeldung
javascript.0 script.js.Test.iLO: Error: ETIMEDOUT: https://192.168.178.8/rest/v1/Chassis/1/Thermal
besagt das dein ILO nicht erreichbar ist
-
8-)
Ein Traum! Herzliches Dankeschön.
Das ist ja schon alles was man benötigt.
Ich werde nun noch mit einem Script die Warnwerte eingeben und eine Warnung per Telegram rausgeben lassen.
Das sollte ich hin bekommen mit Blockly :roll:
Ich werde es dann hier posten. Aber nicht mehr heute.
Soll ich das fertige Script oben mit reinschreiben?
-
@kmx:Soll ich das fertige Script oben mit reinschreiben? `
Währe super dann findet jeder direkt die Lösung, eventuell auch was zum zu einen Adapter um zu bauen ?
–-----------------------
Send from mobile device
-
Adapter wäre sicherlich komfortabler.
Allerdings ist es ja echt nur ein simples script.
Falls wer Lust hat kann es ja gerne machen
-
Welche Wärmewerte willst du per script eingeben?
-
Adapter wäre sicherlich komfortabler.
Allerdings ist es ja echt nur ein simples script.
Falls wer Lust hat kann es ja gerne machen
`
Habs mal in trello eingetragen: https://trello.com/c/1gqUdxms
Die Vorlage ist ja bereits da [emoji28]
–-----------------------
Send from mobile device
-
Welche Wärmewerte willst du per script eingeben? `
Die Warnwerte ab denen es Kritisch wird.
Würde ich aber in ein extra Script packen da es ja von Hardware zu Hardware unterschiedlich ist.
Bei überschreiten oder annäherung an den Wert dann eine Warnung per Telegram.
Adapter wäre sicherlich komfortabler.
Allerdings ist es ja echt nur ein simples script.
Falls wer Lust hat kann es ja gerne machen
`
Habs mal in trello eingetragen: https://trello.com/c/1gqUdxms
Die Vorlage ist ja bereits da [emoji28]
–-----------------------
Send from mobile device `
Danke!
-
Warte mal das kann man gleich mit erledigen im Script.
-
Welche Wärmewerte willst du per script eingeben? `
Die Warnwerte ab denen es Kritisch wird.
Würde ich aber in ein extra Script packen da es ja von Hardware zu Hardware unterschiedlich ist.
Bei überschreiten oder annäherung an den Wert dann eine Warnung per Telegram.
Adapter wäre sicherlich komfortabler.
Allerdings ist es ja echt nur ein simples script.
Falls wer Lust hat kann es ja gerne machen
`
Habs mal in trello eingetragen: https://trello.com/c/1gqUdxms
Die Vorlage ist ja bereits da [emoji28]
–-----------------------
Send from mobile device `
Danke! `
Das mit den Variablen, währe ws nicht sinnvoller diese Werte als object im Baum weg zu schreiben wo auch die Daten stehen. Also zB
-
current
-
trash hold non
-
trash hold max
Kann man dann auch wieder beliebig mit Adapter oder Script X abrufen und logic hinzufügen?
(Zu blöd das ich meinen hp g8 ausfasiert habe sonst könnte ich mit testen)
–-----------------------
Send from mobile device
-
-
Wie meinst du das
> diese Werte als object im Baum weg zu schreiben wo auch die Daten stehen
-
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
-
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.
-
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.
`
Nope ich hab dich falsch verstanden sieht gut aus weiter so [emoji3]
–-----------------------
Send from mobile device