NEWS
[Vorlage] JS: Log-Datei aufbereiten für VIS
-
Peinlicher Fehler beim Skripten aber gern Wär nett von dir.
-
es scheint, als ob das json falsch ist -
fehler:
nach der reparatur:
vielleicht könnte @mic das im script korigieren -
@liv-in-sky super danke. dann hoffen wir mal das @Mic uns hilft
-
Seit zwei, drei Tagen habe ich folgendes Problem. Das Cript läuft, alles ok.
Um 23:59 Eintrag im Log das es aktualisert hat und dann steht im neuen Log2019-10-08 00:00:00.121 - error: javascript.0 script.js.Meine_Geräte.VIS-Logs: monitorLogChanges not executed as starting new Tailing Process was not successful 2019-10-08 00:00:00.130 - info: javascript.0 script.js.Meine_Geräte.VIS-Logs: Start new Tail process. File path to current log: [/opt/iobroker/log/iobroker.2019-10-08.log]
und dann ist Schluß d.h. das Script wird nicht mehr ausgeführt und in VIS tut sich auch nichts mehr mit
neuen Einträgen. Erst wenn ich es neu starte kommen wieder Daten in VIS.
Irgendwie stehe ich auf dem Schlauch bzw. kann mir nicht erklären woran dies liegen könnte.
Hat das vllt hier auch schon mal jemand gehabt. -
An die Interessenten hier ... Schaut Euch mal die JavaScript GitHub-Version an ... https://github.com/ioBroker/ioBroker.javascript/blob/master/docs/en/javascript.md#onlog
-
@apollon77 Danke aber das ist leider zu hoch. Wie müsst das heissen, wenn man nur warn und error von Javaskript Instanz 1 haben will
-
@Stormbringer dann machst du zwei subscribes. Einen pro loglevel und sortierst dann dort in der Funktion nach
if msg.origin == „javscript.1“
-
@apollon77 Sorry ohne Blockly bin ich aufgeschmissen
so?
onLog('error', msg.origin =="javascript.1" { sendTo('telegram.0', {user: 'UserName', text: data.message}); console.log('Following was sent to telegram: ' + data.message); });
-
@apollon77 sagte in [Vorlage] JS: Log-Datei aufbereiten für VIS:
An die Interessenten hier ... Schaut Euch mal die JavaScript GitHub-Version an ... https://github.com/ioBroker/ioBroker.javascript/blob/master/docs/en/javascript.md#onlog
Cool, danke Ist eine neue Funktion des js-Controllers, oder? Damit kann ich das Script sehr stark verschlanken.
@Alle:
Ich habe hier gerade mit dem neuen js-Controller Probleme mit Log-Ausgaben überhaupt (auch ohne dem Script hier), muss erst mal abwarten wie ich das gelöst bekomme (Link). -
-
@Mic Feature mit dem log subscribe ist vom JavaScript Adapter. Controller hat damit nichts zu tun.
-
@Nashra sagte in [Vorlage] JS: Log-Datei aufbereiten für VIS:
Seit zwei, drei Tagen habe ich folgendes Problem. Das Cript läuft, alles ok.
Um 23:59 Eintrag im Log das es aktualisert hat und dann steht im neuen Log2019-10-08 00:00:00.121 - error: javascript.0 script.js.Meine_Geräte.VIS-Logs: monitorLogChanges not executed as starting new Tailing Process was not successful 2019-10-08 00:00:00.130 - info: javascript.0 script.js.Meine_Geräte.VIS-Logs: Start new Tail process. File path to current log: [/opt/iobroker/log/iobroker.2019-10-08.log]
und dann ist Schluß d.h. das Script wird nicht mehr ausgeführt und in VIS tut sich auch nichts mehr mit
neuen Einträgen. Erst wenn ich es neu starte kommen wieder Daten in VIS.
Irgendwie stehe ich auf dem Schlauch bzw. kann mir nicht erklären woran dies liegen könnte.
Hat das vllt hier auch schon mal jemand gehabt.Habe das selbe Problem. Bis zum Tageswechsel läuft alles, danach muss man das Script anhalten und neu starten damit es läuft.
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 ?
-
@ralalla bei mir läuft es bisher noch ohne Probleme, auch nach dem update von java keine Fehler.
Habe, allerdings das Skript im original Zustand und lass mir damit nur die allgemeinen warn/error anzeigen. -
Neue Version 3.0 Alpha: Tester gesucht
Der JavaScript-Adapter in der Latest-Version 4.3.0 bietet die neuen Funktionen onLog() und onLogUnregister().
Damit ist eine deutliche Vereinfachung des Scripts möglich. Vielen Dank an @apollon77 für den Hinweis oben!Es ist nun auch nicht mehr notwendig, node-tail zu nutzen.
Außerdem sollte sich das "Mitternachts-Problem" mancher User damit gelöst haben.
Ebenso erwarte ich hiermit eine deutliche Performanceverbesserung.Würde mich freuen, wenn ihr die neue Version testet.
Hier ist die Test-Version verfügbar: https://github.com/Mic-M/iobroker.logfile-script/blob/master/tester/iobroker_logfile-script_3.0_alpha.jsWICHTIG: Ihr müsst die JavaScript-Adapter-Version 4.3.0 oder höher nutzen (im Latest verfügbar).
Hinweis zum Upgrade von Version 2.0.2: Einfach alles unterhalb von "Ab hier nichts mehr ändern / Stop editing here!" ersetzen.
Vielen Dank fürs Testen. Ich freue mich auf Euer Feedback.
-
@Mic bevor ichs skript starte.... muss die Ordnerstruktur vorher gelöscht werden im Objektbaum?
-
Habs bei mir am Laufen, sieht gut aus!
Vielleicht noch was für zukünftige Releases:
Ein Schalter für das Ein-/Ausschalten der PID im Log:
-
@crunchip sagte in [Vorlage] JS: Log-Datei aufbereiten für VIS:
@Mic bevor ichs skript starte.... muss die Ordnerstruktur vorher gelöscht werden im Objektbaum?
Sollte tatsächlich auch ohne Löschung gehen, kannst du mal ohne Löschen probieren, und bei Problemen bitte Script stoppen, löschen, und dann starten.
-
@Mic ok, ich teste
-
@darkiop sagte in [Vorlage] JS: Log-Datei aufbereiten für VIS:
Vielleicht noch was für zukünftige Releases:
Ein Schalter für das Ein-/Ausschalten der PID im Log:Danke fürs Testen! Sehr guter Hinweis, hab ich schon auf dem Schirm
-
Notiz an mich: PID ausschalten, würde so gehen:
// 2. Newer JavaScript adapter (version 4.3+) adds a 5(?) digit number inside brackets to the beginning of the message. We remove it here. // We cover 3-6 digits, just in case. let regexJsId = /^\([0-9]{3,6}\)\s/ mMessage = mMessage.replace(regexJsId, '');
Muss mal sehen, welche Anzahl an Stellen hier möglich sind, um das sauber einzubauen.