NEWS
Ram läuft voll
-
@d3ltoroxp sagte in Ram läuft voll:
javascript.0 2022-02-07 20:46:34.378 info script.js.Test_Scripte.Ausgabe: 1
sofort und es zeigt leider nur 1 an.
dann probieren wir es damit. ich habe in zeile 20 ein log hinzugefügt
Das sollte jedesmal wenn da was aktualisiert wird im skript log so etwas ausgeben.
Wenn das auch nicht so oft passiert, dann sehe ich im skript nix was einen hohen speicherverbrauch oder performance verursacht.Ausführen:Mon Feb 07 2022 20:52:57 GMT+0100 (Mitteleuropäische Normalzeit)
// momentjs is required as dependecies in javascript adapter const moment = require("moment"); var instances = $(`[id=ical.*.data.table]`); instances.on(ical2CalendarWidget); // remove this, if you know to use your own datapoint let datapointId = 'materialdesignwidgets.calendar.ical2calendar' createState(datapointId, "[]", { read: true, write: false, desc: "JSON String for Calendar Widget", type: "string", def: "[]" }); function ical2CalendarWidget() { try { console.log("ausführen:"+new Date()); let calList = []; for (var inst = 0; inst <= instances.length - 1; inst++) { let icalObj = getState(instances[inst]).val; if (icalObj) { for (var i = 0; i <= icalObj.length - 1; i++) { let item = icalObj[i]; // extract calendar color let calendarName = item._class.split(' ')[0].replace('ical_', ''); let startTime = moment(item._date); let endTime = moment(item._end); let start = startTime.format("YYYY-MM-DD HH:mm"); let end = endTime.format("YYYY-MM-DD HH:mm"); if (startTime.format('HH:mm') === '00:00' && endTime.format('HH:mm') === '00:00') { // is full-day event if (endTime.diff(startTime, 'hours') === 24) { // full-day event, one day start = startTime.format("YYYY-MM-DD"); end = startTime.format("YYYY-MM-DD"); } else { // full-day event, multiple days start = startTime.format("YYYY-MM-DD"); end = endTime.format("YYYY-MM-DD"); } } // create object for calendar widget calList.push({ name: item.event, color: getMyCalendarColor(calendarName), colorText: getMyCalendarTextColor(calendarName), start: start, end: end }) } function getMyCalendarColor(calendarName) { // assign colors via the calendar names, use calendar name as set in ical if (calendarName === 'Geburtstage') { return '#FF8040'; } else if (calendarName === 'Abfallentsorgung') { return '#FFFF00' } else if (calendarName === 'Events') { return '#13EC5F' } else if (calendarName === 'Feiertage') { return '#14ECF0' } else if (calendarName === 'SchulplanPräsenzunterricht') { return '#E31CD2' } } function getMyCalendarTextColor(calendarName) { // assign colors via the calendar names, use calendar name as set in ical if (calendarName === 'calendar1') { return '#FFFFFF'; } else if (calendarName === 'calendar2') { return '#FFFFFF' } else if (calendarName === 'calendar3') { return '#FFFFFF' } } } // Enter the destination data point that is to be used as object ID in the widget setState(datapointId, JSON.stringify(calList), true); } } catch (e) { console.error(`ical2MaterialDesignCalendarWidget: message: ${e.message}, stack: ${e.stack}`); } } ical2CalendarWidget();
-
@oliverio Also in der Log steht irgendwie nichts... Bisher blieb der Ram auch ruhig.
-
@d3ltoroxp
Im Skript-Log / Debug-Fenster
Nicht im iobroker log -
@oliverio Das hier ?
16.2.2022, 17:01:22.292 [info ]: javascript.0 (456) Stop script script.js.VIS.Ical_Umwandler_Calende_Widget 16.2.2022, 17:01:22.301 [info ]: javascript.0 (456) Start javascript script.js.VIS.Ical_Umwandler_Calende_Widget 16.2.2022, 17:01:22.326 [info ]: javascript.0 (456) script.js.VIS.Ical_Umwandler_Calende_Widget: ausführen:Wed Feb 16 2022 17:01:22 GMT+0100 (Mitteleuropäische Normalzeit) 16.2.2022, 17:01:22.335 [warn ]: javascript.0 (456) script.js.VIS.Ical_Umwandler_Calende_Widget: setForeignState(id=javascript.0.materialdesignwidgets.calendar.ical2calendar, state={"val":"[{\"name\":\"Restmüllgefäß\",\"color\":\"#FFFF00\",\"start\":\"2022-02-16\",\"end\":\"2022-02-16\"},{\"name\":\"xxxx 16.2.2022, 17:01:22.335 [info ]: javascript.0 (456) script.js.VIS.Ical_Umwandler_Calende_Widget: registered 1 subscription and 0 schedules 16.2.2022, 17:01:50.309 [info ]: javascript.0 (456) Stop script script.js.VIS.Ical_Umwandler_Calende_Widget 16.2.2022, 17:01:50.314 [info ]: javascript.0 (456) Start javascript script.js.VIS.Ical_Umwandler_Calende_Widget 16.2.2022, 17:01:50.319 [info ]: javascript.0 (456) script.js.VIS.Ical_Umwandler_Calende_Widget: ausführen:Wed Feb 16 2022 17:01:50 GMT+0100 (Mitteleuropäische Normalzeit) 16.2.2022, 17:01:50.322 [info ]: javascript.0 (456) script.js.VIS.Ical_Umwandler_Calende_Widget: registered 1 subscription and 0 schedules
-
@d3ltoroxp sagte in Ram läuft voll:
wurde nicht ausgeführt, während der Debug-Modus aktiv ist
schalt den mal ab und lösch deine privaten Daten im log
-
@d3ltoroxp
ja genau nur hast du es nicht lange laufen lassen.
das skript sollte immer dann so eine Zeile wie bei Zeile 3 und Zeile 8
ausgeben, wenn es eine Änderung gibt.
Eine hohe Performance oder Viel RAM wird auch dann verbraucht, wenn ein Trigger sehr oft aufgerufen wird.
Zumindest in der Zeit 17:01:22 bis 17:01:50 gab es nur einmal den initialen Trigger für den Datenpunkt.Wenn das jetzt sehr oft dran stehen würde,, aber auch hier kein Hinweis auf viel Speicherverbrauch.
Das Skript ist aus meiner Sicht safe -
Also das muss noch aktiv sein ?
Ich hab oben mal die Zeile gelöscht mit den Daten.
Komisch ich habe noch mal zwei Scripte aktiviert, bei denen ich vermutet hätte das sie es sind. Weil komischerweise als sie liefen auch dann das mit dem Ram wieder auftrat. Nach dem deaktivieren war's wieder ruhig paar Tage. Jetzt habe ich die vor 1-2 Tagen wieder aktiviert. Mal sehen...
-
@d3ltoroxp sagte in Ram läuft voll:
Also das muss noch aktiv sein ?
nein!
das debug muss aus - so stand es doch auch im log -
lese dir bitte mal die folgenden threads durch
https://forum.iobroker.net/topic/42792/javascript-heap-out-of-memory-workaround?=1623240989781
https://forum.iobroker.net/topic/40101/gelöst-speicherlecks-im-iobroker?=1623241091971da sind ähnliche fälle mit Vorgehensweisen, wie man das lösen kann.
allerdings kann man keine generelle Standardvorgehensweisen Vorschlagen, da es da doch sehr individiuell wird. -
@oliverio Hm ich nutze von Pettini das Fenster offen Script. Ich habe da zwei am laufen, eins für meine Tore und das andere für Fenster und Türen. Ich meine wenn ich die aktiviere gehts los. Ich hab sie seit 2 Tagen wieder aus und Ruhe ist. Aktiviere ich sie geht es nicht lange und ich kann schon wieder nicht auf ioBroker zugreifen. Muss ich mich mal bei ihm melden.
EDIT::
Definitiv das Script, ich aktiviere es und es geht 1-3 Tage gut danach kackt ioB wieder rum. Mittlerweile schießt er sich immer ab ich komm gar nicht mehr auf das WebIF. Muss die VM immer neu starten.
Deaktiviere ich dieses Script, läuft er Tage lang durch. -
@d3ltoroxp zeige mal das script, evtl sieht man da etwas.
ich gehe mal davon aus, du bis in javascript nicht so gut? -
@oliverio naja hält sich in Grenzen. Das Script ist aber nicht von mir sondern von @Pittini
const Skriptversion = "1.6.15" //vom 22.11.2021 - https://github.com/Pittini/iobroker-Fensterauswertung - https://forum.iobroker.net/topic/31674/vorlage-generisches-fensteroffenskript-vis //Script um offene Fenster/Türen pro Raum und insgesamt zu zählen. //Möglichkeit eine Ansage nach x Minuten einmalig oder zyklisch bis Fensterschließung anzugeben //Dynamische erzeugung einer HTML Übersichtstabelle //WICHTIG!!! //Vorraussetzungen: Den Geräten müssen Räume zugewiesen sein, sowie die Funktion "Fenster" bzw "Tuer" für jeden entsprechenden Datenpunkt. //Grundeinstellungen const logging = false; //Erweiterte Logs ausgeben? const praefix = "0_userdata.0.Tuer_Fenster_Ueberwachung."; //Grundpfad für Script DPs - Muß innerhalb javascript.x sein. const PresenceDp = "" //Pfad zum Anwesenheitsdatenpunkt, leer lassen wenn nicht vorhanden const WhichWindowFunctionToUse = "WindowsStatus"; // Legt fest nach welchem Begriff in Funktionen gesucht wird. Diese Funktion nur dem Datenpunkt zuweisen, NICHT dem ganzen Channel! const WhichDoorFunctionToUse = "TuerStatus"; // Legt fest nach welchem Begriff in Funktionen gesucht wird. Diese Funktion nur dem Datenpunkt zuweisen, NICHT dem ganzen Channel! const WindowIgnoreTime = 10000; // 10000 ms = 10 Sekunden - Zeit in ms für die kurzzeitiges öffnen/schliessen ignoriert wird const DoorIgnoreTime = 5000; // 1000 ms = 1 Sekunden - Zeit in ms für die kurzzeitiges öffnen/schliessen ignoriert wird const WhichEnumCategoryToUse = "functions"; // Legt fest in welcher Kategorie sich die Aufzählungen befinden! Nur ändern wer weis was er tut! //Nachrichteneinstellungen const TimeToWindowMsg = 900000 // 300000 ms = 5 Minuten - Zyklus- bzw. Ablaufzeit für Fenster-offenwarnung/en const TimeToDoorMsg = 60000 // 300000 ms = 5 Minuten - Zyklus- bzw. Ablaufzeit für Tür-offenwarnung/en const MaxMessages = 2; //Maximale Anzahl der Nachrichten pro Raum //Telegram const UseTelegram = false; // Sollen Nachrichten via Telegram gesendet werden? //Pushover const UsePushOver = false; // Sollen Nachrichten via PushOver gesendet werden? const PushOverInstance = "pushover.0"; //Pushoverinstanz welche genutzt werden soll angeben const PushOverDevice = "All"; //Welches Gerät soll die Nachricht bekommen const PushOverTitle = "Fensterüberwachung"; const PushOverSound = "none"; //Welcher Sound soll abgespielt werden? "none" für kein Sound, "" für Standartsound, ansonsten Namen angeben z.B. "magic" //Alexa const UseAlexa = true; // Sollen Nachrichten via Alexa ausgegeben werden? const AlexaInstance = "alexa2.0"; const AlexaId = "G091ET06039404PA"; // Die Alexa Seriennummer. const AlexaVolume = "50"; // Lautstärke der Nachrichten. Wert von 1 bis 100 //Other const UseMail = false; //Nachricht via Mail versenden? const UseSay = false; // Sollen Nachrichten via Say ausgegeben werden? Autorenfunktion, muß deaktiviert werden. const UseEventLog = false; // Sollen Nachrichten ins Eventlog geschreiben werden? Autorenfunktion, muß deaktiviert werden. const NoMsgAtPresence = false; //Sollen Nachrichten bei Anwesenheit unterdrückt werden? //Tabelleneinstellungen const DoorOpenImg = "/icons-mfd-svg/fts_door_open.svg"; //Icon für Tür offen const DoorCloseImg = "/icons-mfd-svg/fts_door.svg"; // Icon für Tür geschlossen const DoorTiltedImg = "/icons-mfd-svg/fts_door_tilt.svg" // Icon für Tür gekippt const WindowOpenImg = "/icons-mfd-svg/fts_window_1w_open.svg"; //Icon für Fenster offen const WindowCloseImg = "/icons-mfd-svg/fts_window_1w.svg"; // Icon für Fenster geschlossen const WindowTiltedImg = "/icons-mfd-svg/fts_window_1w_tilt.svg" //Icon für Fenster gekippt const WindowOpenTiltedImg = "/icons-mfd-svg/fts_window_2w_open_l_tilt_r.svg" //Icon für offen und gekippt in einem Raum gleichzeitig const VentImg = "/icons-mfd-svg/vent_ventilation.svg"; //Icon für Lüftungsinfo const ImgInvert = 1; // Bildfarben invertieren? Erlaubte Werte von 0 bis 1 const OpenWindowColor = "#f44336"; // Farbe für Fenster offen const OpenDoorColor = "darkorange"; //Farbe für Tür offen const TiltedWindowColor = "#F56C62"; //Farbe für gekippte Fenster o. Tür/en const ClosedWindowColor = "#4caf50"; // Farbe für geschlossene Fenster o. Tür/en const VentWarnColor = "#ffc107"; // Farbe für Lüftungswarnung const ShowCaptionTbl = false; // Überschrift anzeigen? const ShowSummaryTbl = true; // Zusammenfassung anzeigen? const ShowDetailTbl = true; // Details anzeigen? const RoomSortMode = 1; //0= Raumliste unsortiert, 1= alpabetisch sortiert, 2= Benutzerdefinierte Sortierung //Logeinstellungen const MaxLogEntrys = 20; //Maximale Anzahl der zu speichernden Logeinträge const AutoAddTimestamp = true; //Soll den geloggten Nachrichten automatisch ein Zeitsempel zugeordnet werden? const LogTimeStampFormat = "TT.MM.JJJJ SS:mm:ss"; //Zeitformatierung für Log Zeitstempel const LogEntrySeparator = "<br>"; //Trennzeichen für Logeinträge
Der Rest sprengt das erlaubte...
-
@d3ltoroxp
ok, sehr umfangreich.prüfe nochmal ob du gemäß Anleitung alles korrekt eingestellt und konfiguriert hast.
Dann muss der Skriptersteller ran.
Ich weiß ja nicht wie viele dieses Skript hier noch verwenden.
Wenn es Problem des Skripts ist, dann müssten sich ja noch mehr beschweren. -
@oliverio Hab das script auch noch mal neu geladen und eingestellt. Aber hab mich jetzt da mal im Thread gemeldet, es ist eindeutig... Wenn an dann kommen die Problem, wenn aus läuft er Tagelang ruhig.
-
@d3ltoroxp sagte in Ram läuft voll:
Ich habe da zwei am laufen, eins für meine Tore und das andere für Fenster und Türen.
Lass mal nur eins davon laufen und schau ob das Problem bestehen bleibt. Von 2 laufenden Skripten hast im anderen Thread nix geschrieben, da hab ich bei allen möglichen Skripten schon Probs gesehen wenn die nich sauber getrennt sind, oder gleichzeitig iwas auslösen etc.
-
@pittini said in Ram läuft voll:
@d3ltoroxp sagte in Ram läuft voll:
Ich habe da zwei am laufen, eins für meine Tore und das andere für Fenster und Türen.
Lass mal nur eins davon laufen und schau ob das Problem bestehen bleibt. Von 2 laufenden Skripten hast im anderen Thread nix geschrieben, da hab ich bei allen möglichen Skripten schon Probs gesehen wenn die nich sauber getrennt sind, oder gleichzeitig iwas auslösen etc.
Hm 6 Tage war Ruhe, heute Vormittag das Script 1x gestartet, eben wieder am Limit gewesen.
Aber im Script habe ich ja nicht wirklich was gemacht ausser im oberen Bereich, wo man einstellt.
const Skriptversion = "1.6.15" //vom 22.11.2021 - https://github.com/Pittini/iobroker-Fensterauswertung - https://forum.iobroker.net/topic/31674/vorlage-generisches-fensteroffenskript-vis //Script um offene Fenster/Türen pro Raum und insgesamt zu zählen. //Möglichkeit eine Ansage nach x Minuten einmalig oder zyklisch bis Fensterschließung anzugeben //Dynamische erzeugung einer HTML Übersichtstabelle //WICHTIG!!! //Vorraussetzungen: Den Geräten müssen Räume zugewiesen sein, sowie die Funktion "Fenster" bzw "Tuer" für jeden entsprechenden Datenpunkt. //Grundeinstellungen const logging = false; //Erweiterte Logs ausgeben? const praefix = "0_userdata.0.Tuer_Fenster_Ueberwachung."; //Grundpfad für Script DPs - Muß innerhalb javascript.x sein. const PresenceDp = "" //Pfad zum Anwesenheitsdatenpunkt, leer lassen wenn nicht vorhanden const WhichWindowFunctionToUse = "WindowsStatus"; // Legt fest nach welchem Begriff in Funktionen gesucht wird. Diese Funktion nur dem Datenpunkt zuweisen, NICHT dem ganzen Channel! const WhichDoorFunctionToUse = "TuerStatus"; // Legt fest nach welchem Begriff in Funktionen gesucht wird. Diese Funktion nur dem Datenpunkt zuweisen, NICHT dem ganzen Channel! const WindowIgnoreTime = 10000; // 10000 ms = 10 Sekunden - Zeit in ms für die kurzzeitiges öffnen/schliessen ignoriert wird const DoorIgnoreTime = 5000; // 1000 ms = 1 Sekunden - Zeit in ms für die kurzzeitiges öffnen/schliessen ignoriert wird const WhichEnumCategoryToUse = "functions"; // Legt fest in welcher Kategorie sich die Aufzählungen befinden! Nur ändern wer weis was er tut! //Nachrichteneinstellungen const TimeToWindowMsg = 900000 // 300000 ms = 5 Minuten - Zyklus- bzw. Ablaufzeit für Fenster-offenwarnung/en const TimeToDoorMsg = 60000 // 300000 ms = 5 Minuten - Zyklus- bzw. Ablaufzeit für Tür-offenwarnung/en const MaxMessages = 2; //Maximale Anzahl der Nachrichten pro Raum //Telegram const UseTelegram = false; // Sollen Nachrichten via Telegram gesendet werden? //Pushover const UsePushOver = false; // Sollen Nachrichten via PushOver gesendet werden? const PushOverInstance = "pushover.0"; //Pushoverinstanz welche genutzt werden soll angeben const PushOverDevice = "All"; //Welches Gerät soll die Nachricht bekommen const PushOverTitle = "Fensterüberwachung"; const PushOverSound = "none"; //Welcher Sound soll abgespielt werden? "none" für kein Sound, "" für Standartsound, ansonsten Namen angeben z.B. "magic" //Alexa const UseAlexa = true; // Sollen Nachrichten via Alexa ausgegeben werden? const AlexaInstance = "alexa2.0"; const AlexaId = "G091ET06039404PA"; // Die Alexa Seriennummer. const AlexaVolume = "50"; // Lautstärke der Nachrichten. Wert von 1 bis 100 //Other const UseMail = false; //Nachricht via Mail versenden? const UseSay = false; // Sollen Nachrichten via Say ausgegeben werden? Autorenfunktion, muß deaktiviert werden. const UseEventLog = false; // Sollen Nachrichten ins Eventlog geschreiben werden? Autorenfunktion, muß deaktiviert werden. const NoMsgAtPresence = false; //Sollen Nachrichten bei Anwesenheit unterdrückt werden? //Tabelleneinstellungen const DoorOpenImg = "/icons-mfd-svg/fts_door_open.svg"; //Icon für Tür offen const DoorCloseImg = "/icons-mfd-svg/fts_door.svg"; // Icon für Tür geschlossen const DoorTiltedImg = "/icons-mfd-svg/fts_door_tilt.svg" // Icon für Tür gekippt const WindowOpenImg = "/icons-mfd-svg/fts_window_1w_open.svg"; //Icon für Fenster offen const WindowCloseImg = "/icons-mfd-svg/fts_window_1w.svg"; // Icon für Fenster geschlossen const WindowTiltedImg = "/icons-mfd-svg/fts_window_1w_tilt.svg" //Icon für Fenster gekippt const WindowOpenTiltedImg = "/icons-mfd-svg/fts_window_2w_open_l_tilt_r.svg" //Icon für offen und gekippt in einem Raum gleichzeitig const VentImg = "/icons-mfd-svg/vent_ventilation.svg"; //Icon für Lüftungsinfo const ImgInvert = 1; // Bildfarben invertieren? Erlaubte Werte von 0 bis 1 const OpenWindowColor = "#f44336"; // Farbe für Fenster offen const OpenDoorColor = "darkorange"; //Farbe für Tür offen const TiltedWindowColor = "#F56C62"; //Farbe für gekippte Fenster o. Tür/en const ClosedWindowColor = "#4caf50"; // Farbe für geschlossene Fenster o. Tür/en const VentWarnColor = "#ffc107"; // Farbe für Lüftungswarnung const ShowCaptionTbl = false; // Überschrift anzeigen? const ShowSummaryTbl = true; // Zusammenfassung anzeigen? const ShowDetailTbl = true; // Details anzeigen? const RoomSortMode = 1; //0= Raumliste unsortiert, 1= alpabetisch sortiert, 2= Benutzerdefinierte Sortierung //Logeinstellungen const MaxLogEntrys = 20; //Maximale Anzahl der zu speichernden Logeinträge const AutoAddTimestamp = true; //Soll den geloggten Nachrichten automatisch ein Zeitsempel zugeordnet werden? const LogTimeStampFormat = "TT.MM.JJJJ SS:mm:ss"; //Zeitformatierung für Log Zeitstempel const LogEntrySeparator = "<br>"; //Trennzeichen für Logeinträge
-
Am 1.3. deaktiviert und am 6.3. wieder aktiviert. Eins alleine. Zudem läuft noch das Batterie Script von dir @Pittini
Ram war paar mal voll. ioBroker geht wieder nicht.
-
@d3ltoroxp Keine Ahnung was da schief läuft. Ich und zig andere haben meine Skripte laufen ohne dieses Problem. Soll heißen, sorry, da kann ich Dir leider nicht helfen.
-
@d3ltoroxp sagte in Ram läuft voll:
Skriptversion = "1.6.15"
ich hab z.b. noch 1.6.12 laufen, vllt gehst du auch mal zurück
oder es liegt an deinen Sensoren -
@crunchip said in Ram läuft voll:
@d3ltoroxp sagte in Ram läuft voll:
Skriptversion = "1.6.15"
ich hab z.b. noch 1.6.12 laufen, vllt gehst du auch mal zurück
oder es liegt an deinen SensorenAn den Aqara Fensterkontakten ?
Ich habe das Script auch schon länger im Einsatz und das lief eigentlich super. Erst seit Hardware Wechsel und Update auf neueren Admin und das was alles dazu gehört, macht es so mucken.