NEWS
[Vorlage] JS: Log-Datei aufbereiten für VIS
-
@Bluelightcrew neue Version nutzen, dann läufts durch
-
@Nashra
Problem ist das mein Js Adapter 4.1.12 ist ,da ich stable nutze. -
@Bluelightcrew
Dann entweder warten, bis dieser im Stable ist, oder alternativ den Latest installieren.@ralalla sagte in [Vorlage] JS: Log-Datei aufbereiten für VIS:
Ebenso bekomme ich es nicht hin das ganze "schön" in einer Tabelle anzeigen zu lassen. Kann noch mal jemand ein paar Infos dazu geben wie das am besten gemacht wird ?
Siehe etwa hier: https://forum.iobroker.net/post/303374
-
Nabend,
wäre es möglich Telegram einzubauen?
Ich würde gerne alle richtigen Error Meldungen per Telegram haben.
Das ganze soll immer nur einmal geschickt werden (neueste oder aktueller Error) und keine komplette Liste mit allen Error Meldungen.
(bzw. wenn es ein Error ist der mehrere Zeilen schreibt dann halt dann doch mehrere)
ioBroker ist ja inzwischen so stabil am laufen das zumindest bei mir nur noch Error Meldungen kommen wenn was nicht stimmt.Optional wäre es auch total klasse wenn man das, wie du es ja bereits eingebaut hast, auch für normale Logs/Adapter machen könnte falls man mal einen Adapter überwachen möchte.
Ist so etwas zu realisieren?
-
Hi,
geht natürlich, und könnte man auch über ein separates JavaScript lösen.
Also gewünschten Datenpunkt auf Änderung überwachen, dann müssen halt verschiedene Vergleiche laufen, bevor tatsächlich eine Meldung abgegeben wird.Was müsste man denn prüfen, um nicht alle paar Sekunden eine Meldung zu erhalten?
Ich brauche da euren Input, um verschiedenes abzufangen, wie etwa- Absturz / Endlosschleifen und ioBroker-Log wird vollgemüllt
- Begrenzungen (also wie oft)
- ...
Also in etwa nur senden, falls:
- Letzte Log-Eintrag-Meldung ungleich der aktuellen (+ ggf. Zeitunterschied, d.h. wenn alle 12 Stunden derselbe Logeintrag kommt, möchte man das schon wissen, alle 2 Sekunden aber nicht...)
- UND Letzter (Telegram-)Befehl vor länger als xxx Sekunden gesendet
- UND Falls mehr als xx mal innerhalb von xx Sekunden gesendet wird, dann nicht mehr senden
Was wären sonst noch sinnvolle / andere Bedingungen?
Am besten du überlegst mal, was hier sinnvoll wäre für den Einsatzzweck und schreibst es hier rein
-
@Mic
Hallo Mic,
saubere Arbeit !Ich habe auch schon die ältere Version des Scriptes genutzt und hatte ebenfalls das "Mitternachts-Problem".
Habe mir dann (mit meinen rudimentären JavaScript-Kenntnissen) so geholfen, daß ich erstens den Schedule auf jede 45te Sekunde gesetzt habe ( also nicht alle 45 Sek), damit auf jeden Fall immer 15 Sekunden Zeit bis zum "Mitternacht-Wechsel" war:const STATE_UPDATE_SCHEDULE = '45 * * * * *'; // jede 45te Sekunde
und zweitens die function init() geforked habe, d.h. die function main() erst 15 Sekunden nach Mitternacht habe ausführen lassen:
// Every midnight at 0:00, we have a new log file. So, we schedule accordingly. //clearSchedule(G_Schedule_Midnight); //G_Schedule_Midnight = schedule('0 0 * * *', main); //Forked by joergeli: Every midnight at 0:00 + 15 seconds, we have a new log file. So, we schedule accordingly. clearSchedule(G_Schedule_Midnight); G_Schedule_Midnight = schedule('15 0 0 * * *', main);
Damit hatte ich dann das "Mitternachts-Problem nicht mehr.
Aber das gehört wohl jetzt mit Deinem neuen Script der Vergangenheit an.Trotzdem habe ich - für mich persönlich! - auch im neuen Script wieder etwas "herumgepfuscht".
Worum geht's ? Nun, ich wollte gerne, wenn ich das Log manuell lösche (clearJSON), daß das auch im vis optisch angezeigt wird.
Mein Log sieht im vis so aus:
Im vis habe ich mir oben rechts in der Tabelle einen Button (Widget jqui - Button State) eingebaut, der das Log löscht:
Zusätzlich habe ich die function subscribeClearJson() wie folgt geforked;
function subscribeClearJson() { // Set current date to state if button is pressed let logSubscribe = ''; for (let i = 0; i < LOG_FILTER.length; i++) { let lpFilterId = cleanseStatePath(LOG_FILTER[i].id); let lpStateFirstPart = LOG_STATE_PATH + '.log' + lpFilterId; logSubscribe += ( (logSubscribe === '') ? '' : ', ') + lpFilterId; on({id: lpStateFirstPart + '.clearJSON', change: 'any', val: true}, function(obj) { let stateBtnPth = obj.id // e.g. [javascript.0.Log-Script.logInfo.clearJSON] let firstPart = stateBtnPth.substring(0, stateBtnPth.length-10); // get first part of obj.id, like "javascript.0.Log-Script.logInfo" let filterID = firstPart.slice(firstPart.lastIndexOf('.') + 1); // gets the filter id, like "logInfo" if (LOG_DEBUG) log(DEBUG_IGNORE_STR + 'Clear JSON states for [' + filterID + '].'); //______Forked by joergeli: Show a notice in vis-Table, that log was deleted __________________________________________________ // We clear the according JSON states //deactivated //setState(firstPart + '.logJSON', '[]'); //deactivated var datum = new Date(); var tag = datum.getDate(); var monat = (datum.getMonth()+ 1); var jahr = datum.getFullYear(); var stunde = datum.getHours(); var minute = datum.getMinutes(); var sekunde = datum.getSeconds(); if (tag < 10) tag = '0' + tag; if (monat < 10) monat= '0' + monat; if (stunde< 10) stunde= '0' + stunde; if (minute< 10) minute= '0' + minute; if (sekunde< 10) sekunde= '0' + sekunde; var loeschdatum = tag + "." + monat+"." + jahr; var loeschzeit = stunde +":" + minute +":" + sekunde; setState(firstPart + '.logJSON', ' [{"date": "" ,"level":"","source":"","msg":"<span class=\'log-deleted\'> Log wurde gelöscht ( ' + loeschdatum + ' um ' + loeschzeit + ' Uhr ) </span>"}]'); //____________________________________________________________________________________________________________ setState(firstPart + '.logJSONcount', 0); }); } if (LOG_DEBUG) log('Subscribing to Clear JSON Buttons: ' + logSubscribe) }
Außerdem habe ich mir noch ein css für die Logging-Tabelle angelegt (Farben, Schriftgröße, Ränder, etc.)
Anschließend das Widget basic-table der entspr. CSS-Klasse logging zugeordnet..log-info{ color: #0B610B; font-weight: bold; } .log-warn { color: #ffaa00; font-weight: bold; } .log-error{ color: red; font-weight: bold;} .log-deleted{ color: #990000; background-color: #eeee66; font-family:arial; font-size: 10px; font-weight: bold; } .logging{ border-collapse: collapse; border: 0px solid #6a6a6a; } .logging th{ background-color: #5297ff; color: #ffffff; font-size: 11px; font-weight: bold; border: none; height:17px; border-color:#6a6a6a; border-bottom-style:solid; border-width:1px; } /* gerade Zeilen */ .logging-tr:nth-child(even) { background-color: #DDF5DB; color: #4a4a4a; font-size: 11px; } /* ungerade Zeilen */ .logging-tr:nth-child(odd) { background-color: #EDFAE8; color: #4a4a4a; font-size: 11px; }
Dann wird nach dem manuellen Löschen des Logs in der ersten Zeile der Löschzeitpunkt schön farbig angezeigt.
Natürlich nur so lange, bis das durch einen Log-Eintrag überschrieben wird.
Zugegeben, das ist nur eine optische Spielerei und könnte man scriptmäßig bestimmt eleganter lösen, ist aber evtl. eine Anregung für andere "Spielkinder"Hinweis an alle: Bitte nicht in Mic's Script rumbasteln, wenn man nicht genau weiß was man tut!
Also Mic, nochmals Danke für Dein Script
Gruß
Jörg -
@Mic
Hallo Mic,
ich noch mal.
Mitternacht ist gerade vorbei und ich habe im Log festgestellt, daß mit dem neuen Script jetzt nur noch die Log-Einträge des aktuellen Tages vorhanden sind.
Beim "alten" Script blieben die Einträge des Vortages erhalten.
Ist das so gewollt, bzw. könnte man das wieder abändern, daß die alten Einträge erhalten bleiben?
Also quasi wie bisher ein "rollierendes" Log ( first in - last out).Gruß
Jörg -
Ja das kommt der Sache schon extrem nahe.
Telegram soll halt auch nicht zugemüllt werden.Sage mal so.
Error tritt auf. Script wartet kurz ob noch mehr error kommen, wenn ja zusammenführen, wenn nein senden.
Error merken für Zeit x damit nicht nochmal gesendet wird.Ggf ein Menü einbauen falls man explizit nachfragt kommen mehr Infos. Aktueller Fehler ist seit dem noch 5 mal aufgetreten.
Muss ich mir heute Abend mal genauer Gedanken machen, nur Scripten kann ich so eine Abfrage leider nicht das ist mir noch zu hoch:)
-
-
@Mic sagte in [Vorlage] JS: Log-Datei aufbereiten für VIS:
Update:
Script siehe hier:Hi Mic!
Ich habe gerade dein aktuelles Script für mich angepasst und beim Start hagelt es leider nur so von Fehlermeldungen.
javascript.0 2019-11-04 17:08:02.012 error at TCP.onStreamRead [as onread] (internal/stream_base_commons.js:94:17) javascript.0 2019-11-04 17:08:02.012 error at Socket.Readable.push (_stream_readable.js:223:10) javascript.0 2019-11-04 17:08:02.012 error at readableAddChunk (_stream_readable.js:268:11) javascript.0 2019-11-04 17:08:02.012 error at addChunk (_stream_readable.js:287:12) javascript.0 2019-11-04 17:08:02.011 error at Socket.emit (events.js:198:13) javascript.0 2019-11-04 17:08:02.011 error at Socket.realHandler (/opt/iobroker/node_modules/ws/lib/WebSocket.js:825:20) javascript.0 2019-11-04 17:08:02.011 error at Receiver.add (/opt/iobroker/node_modules/ws/lib/Receiver.js:103:24) javascript.0 2019-11-04 17:08:02.011 error at Receiver.expectHandler (/opt/iobroker/node_modules/ws/lib/Receiver.js:499:31) javascript.0 2019-11-04 17:08:02.011 error at Receiver.finish (/opt/iobroker/node_modules/ws/lib/Receiver.js:541:12) javascript.0 2019-11-04 17:08:02.011 error at Receiver.flush (/opt/iobroker/node_modules/ws/lib/Receiver.js:347:3) javascript.0 2019-11-04 17:08:02.011 error at /opt/iobroker/node_modules/ws/lib/Receiver.js:508:14 javascript.0 2019-11-04 17:08:02.011 error at Receiver.applyExtensions (/opt/iobroker/node_modules/ws/lib/Receiver.js:371:5) javascript.0 2019-11-04 17:08:02.011 error at /opt/iobroker/node_modules/ws/lib/Receiver.js:536:18 javascript.0 2019-11-04 17:08:02.011 error at Receiver.ontext (/opt/iobroker/node_modules/ws/lib/WebSocket.js:841:10) javascript.0 2019-11-04 17:08:02.011 error at WebSocket.emit (events.js:198:13) javascript.0 2019-11-04 17:08:02.011 error at WebSocket.onMessage (/opt/iobroker/node_modules/ws/lib/WebSocket.js:442:14) javascript.0 2019-11-04 17:08:02.011 error at WebSocket.ws.onmessage (/opt/iobroker/node_modules/engine.io-client/lib/transports/websocket.js:146:10) javascript.0 2019-11-04 17:08:02.011 error at WS.Transport.onData (/opt/iobroker/node_modules/engine.io-client/lib/transport.js:137:8) javascript.0 2019-11-04 17:08:02.011 error at WS.Transport.onPacket (/opt/iobroker/node_modules/engine.io-client/lib/transport.js:145:8) javascript.0 2019-11-04 17:08:02.011 error at WS.Emitter.emit (/opt/iobroker/node_modules/engine.io-client/node_modules/component-emitter/index.js:133:20) javascript.0 2019-11-04 17:08:02.011 error at WS.<anonymous> (/opt/iobroker/node_modules/engine.io-client/lib/socket.js:268:10) javascript.0 2019-11-04 17:08:02.011 error at Socket.onPacket (/opt/iobroker/node_modules/engine.io-client/lib/socket.js:451:14) javascript.0 2019-11-04 17:08:02.011 error at Socket.Emitter.emit (/opt/iobroker/node_modules/engine.io-client/node_modules/component-emitter/index.js:133:20) javascript.0 2019-11-04 17:08:02.011 error at Socket.<anonymous> (/opt/iobroker/node_modules/component-bind/index.js:21:15) javascript.0 2019-11-04 17:08:02.011 error at Manager.ondata (/opt/iobroker/node_modules/socket.io-client/lib/manager.js:322:16) javascript.0 2019-11-04 17:08:02.011 error at Decoder.add (/opt/iobroker/node_modules/socket.io-parser/index.js:246:12) javascript.0 2019-11-04 17:08:02.011 error at Decoder.Emitter.emit (/opt/iobroker/node_modules/component-emitter/index.js:134:20) javascript.0 2019-11-04 17:08:02.010 error at Decoder.<anonymous> (/opt/iobroker/node_modules/component-bind/index.js:21:15) javascript.0 2019-11-04 17:08:02.010 error at Manager.ondecoded (/opt/iobroker/node_modules/socket.io-client/lib/manager.js:332:8) javascript.0 2019-11-04 17:08:02.010 error at Manager.Emitter.emit (/opt/iobroker/node_modules/socket.io-client/node_modules/component-emitter/index.js:133:20) javascript.0 2019-11-04 17:08:02.010 error at Manager.<anonymous> (/opt/iobroker/node_modules/component-bind/index.js:21:15) javascript.0 2019-11-04 17:08:02.010 error at Socket.onpacket (/opt/iobroker/node_modules/socket.io-client/lib/socket.js:236:12) javascript.0 2019-11-04 17:08:02.010 error at Socket.onack (/opt/iobroker/node_modules/socket.io-client/lib/socket.js:312:9) javascript.0 2019-11-04 17:08:02.010 error at Socket.adapter.getForeignState (/opt/iobroker/node_modules/iobroker.javascript/main.js:845:17) javascript.0 2019-11-04 17:08:02.010 error at createProblemObject (/opt/iobroker/node_modules/iobroker.javascript/main.js:1254:17) javascript.0 2019-11-04 17:08:02.010 error at prepareScript (/opt/iobroker/node_modules/iobroker.javascript/main.js:1201:37) javascript.0 2019-11-04 17:08:02.010 error at compile (/opt/iobroker/node_modules/iobroker.javascript/main.js:978:28) javascript.0 2019-11-04 17:08:02.009 error at Object.createScript (vm.js:277:10) javascript.0 2019-11-04 17:08:02.009 error at new Script (vm.js:83:7) javascript.0 2019-11-04 17:08:02.009 error SyntaxError: Unexpected token * javascript.0 2019-11-04 17:08:02.009 error ^ javascript.0 2019-11-04 17:08:02.007 error */ javascript.0 2019-11-04 17:08:02.006 error at script.js.common.ioBroker_Log:263 javascript.0 2019-11-04 17:08:02.006 error script.js.common.ioBroker_Log compile failed:
Könntest du bitte drüberschaun, ob ich irgendwo was falsch konfiguriert habe?
Danke dir!!
-
javascript.0 2019-11-04 17:08:02.009 error SyntaxError: Unexpected token *
javascript.0 2019-11-04 17:08:02.009 error ^
javascript.0 2019-11-04 17:08:02.007 error */
javascript.0 2019-11-04 17:08:02.006 error at script.js.common.ioBroker_Log:263
javascript.0 2019-11-04 17:08:02.006 error script.js.common.ioBroker_Log compile failed:Da ist ein Sternchen ( * ) reingekommen !!
ändere mal auf :
//
-
@Glasfaser sagte in [Vorlage] JS: Log-Datei aufbereiten für VIS:
Da ist ein Sternchen ( * ) reingekommen !!
Danke!
Wie lange dauert es, bis das 1. mal was in den Objekten steht?
Derzeit ist noch alles leer! -
Erzeuge mal absichtlich ein Error Meldung !!
-
@Glasfaser sagte in [Vorlage] JS: Log-Datei aufbereiten für VIS:
Erzeuge mal absichtlich ein Error Meldung !!
funktioniert.
Danke -
Kein Problem
-
@Glasfaser sagte in [Vorlage] JS: Log-Datei aufbereiten für VIS:
Kein Problem
kannst du mir nochmal weiterhelfen?
Wie zeig ich das am besten in VIS an?
Ich hab zB den DP:
javascript.0.Log-Script.logWarnanderror.log
Mit diesem Inhalt:
2019-11-04 20:43:30.720 - warn: denon.0 [2 Einträge] AVR timed out due to no response2019-11-04 20:43:10.087 - warn: host.iobroker [3 Einträge] "system.host.ioBroker-RasPi4" is offline2019-11-04 20:35:03.037 - error: fb-checkpresence.0 Error getHostNo: undefined2019-11-04 20:35:03.037 - error: fb-checkpresence.0 soapAction error: Error: connect EHOSTUNREACH 10.0.1.1:490002019-11-04 20:18:13.308 - warn: admin.0 [2 Einträge] No repository source configured
Dann auch noch diesen DP:
javascript.0.Log-Script.logWarnanderror.logJSON
Mit diesem Inhalt:
[{"date":"04.11.2019 20:43","level":"<span class='log-warn'>warn</span>","source":"denon.0","msg":"[2 Einträge] AVR timed out due to no response"},{"date":"04.11.2019 20:43","level":"<span class='log-warn'>warn</span>","source":"host.iobroker","msg":"[3 Einträge] \"system.host.ioBroker-RasPi4\" is offline"},{"date":"04.11.2019 20:35","level":"<span class='log-error'>error</span>","source":"fb-checkpresence.0","msg":"Error getHostNo: undefined"},{"date":"04.11.2019 20:35","level":"<span class='log-error'>error</span>","source":"fb-checkpresence.0","msg":"soapAction error: Error: connect EHOSTUNREACH 10.0.1.1:49000"},{"date":"04.11.2019 20:18","level":"<span class='log-warn'>warn</span>","source":"admin.0","msg":"[2 Einträge] No repository source configured"}]
Als Basic-Table sieht es kacke aus und ich weis nicht wie ich diese Tabelle anpassen/aufhübschen könnte.
-
-
@Glasfaser sagte in [Vorlage] JS: Log-Datei aufbereiten für VIS:
Nimm mein Widget :
Danke
Bin noch am überlegen ob ich das Log-Script weiterverwende oder nicht.
In der Zeit wo der Cron läuft wird das System doch sehr träge. Und das trotz sehr guter Hardware.
-
-
@Negalein sagte in [Vorlage] JS: Log-Datei aufbereiten für VIS:
In der Zeit wo der Cron läuft wird das System doch sehr träge. Und das trotz sehr guter Hardware.
Das stimmt, ich schalte es nur manchmal ein.