Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Error/Bug
    4. Ram läuft voll

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    Ram läuft voll

    This topic has been deleted. Only users with topic management privileges can see it.
    • D3ltoroxp
      D3ltoroxp @OliverIO last edited by

      @oliverio Schau ich mal rein, weiß nur nicht genau, wie ich das ermitteln soll ? Das Script dürfte von @Scrounger sein für sein Kalender Widget.

      1 Reply Last reply Reply Quote 0
      • OliverIO
        OliverIO @D3ltoroxp last edited by

        @d3ltoroxp sagte in Ram läuft voll:

        var instances = $(`[id=ical.*.data.table]`);
        console.log(instances.length);
        
        D3ltoroxp 1 Reply Last reply Reply Quote 0
        • D3ltoroxp
          D3ltoroxp @OliverIO last edited by

          @oliverio Den DP hab ich gefunden, soll ich alles was dort drin steht posten ?

          OliverIO 1 Reply Last reply Reply Quote 0
          • OliverIO
            OliverIO @D3ltoroxp last edited by

            @d3ltoroxp wieso den datenpunkt?
            du sollst das skript ausführen was ich gepostet habe.
            das zählt die anzahl der states, die durch den filter angezogen werden.
            die zahl die da im skript-log ausgegeben wird postest du hier.
            ich gehe davon aus das es eine sehr hohe zahl ist

            D3ltoroxp 1 Reply Last reply Reply Quote 0
            • D3ltoroxp
              D3ltoroxp @OliverIO last edited by

              @oliverio ach jetzt kapier ich, ich dachte immer das wäre ein Ausschnitt aus dem Script was ich gepostet hatte ? Ei jei jei.

              Sollte das sofort was anzeigen oder erst wenn das eigentliche Script durchläuft ?

              javascript.0
              	2022-02-07 20:46:34.378	info	script.js.Test_Scripte.Ausgabe: registered 0 subscriptions and 0 schedules
              javascript.0
              	2022-02-07 20:46:34.378	info	script.js.Test_Scripte.Ausgabe: 1
              javascript.0
              	2022-02-07 20:46:34.363	info	Start javascript script.js.Test_Scripte.Ausgabe
              javascript.0
              	2022-02-07 20:46:31.769	info	Stop script script.js.Test_Scripte.Ausgabe
              
              bahnuhr OliverIO 2 Replies Last reply Reply Quote 0
              • bahnuhr
                bahnuhr Forum Testing Most Active @D3ltoroxp last edited by

                @d3ltoroxp

                Ne, du hast es nicht verstanden !

                Du sollst die Zeile mit dem "log" hinter deiner zeile mit dem selektor einfügen.
                und dann laufen lassen.
                Im log erscheint dann eine zahl und die sollst du zeigen.

                D3ltoroxp 1 Reply Last reply Reply Quote 0
                • D3ltoroxp
                  D3ltoroxp @bahnuhr last edited by D3ltoroxp

                  @bahnuhr

                  // momentjs is required as dependecies in javascript adapter
                  const moment = require("moment");
                  
                  var instances = $(`[id=ical.*.data.table]`);
                  console.log(instances.length);
                  instances.on(ical2CalendarWidget);
                  
                  // remove this, if you know to use your own datapoint
                  
                  20:51:40.819	info	javascript.0 (456) script.js.VIS.Ical_Umwandler_Calende_Widget: 1
                  

                  456 ist die gesuchte Zahl ?

                  1 Reply Last reply Reply Quote 0
                  • OliverIO
                    OliverIO @D3ltoroxp last edited by OliverIO

                    @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();
                    
                    
                    D3ltoroxp 1 Reply Last reply Reply Quote 0
                    • D3ltoroxp
                      D3ltoroxp @OliverIO last edited by

                      @oliverio Also in der Log steht irgendwie nichts... Bisher blieb der Ram auch ruhig.

                      OliverIO 1 Reply Last reply Reply Quote 0
                      • OliverIO
                        OliverIO @D3ltoroxp last edited by

                        @d3ltoroxp
                        Im Skript-Log / Debug-Fenster
                        Nicht im iobroker log

                        D3ltoroxp 1 Reply Last reply Reply Quote 0
                        • D3ltoroxp
                          D3ltoroxp @OliverIO last edited by D3ltoroxp

                          @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
                          
                          Homoran OliverIO 2 Replies Last reply Reply Quote 0
                          • Homoran
                            Homoran Global Moderator Administrators @D3ltoroxp last edited by

                            @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

                            1 Reply Last reply Reply Quote 0
                            • OliverIO
                              OliverIO @D3ltoroxp last edited by

                              @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

                              1 Reply Last reply Reply Quote 0
                              • D3ltoroxp
                                D3ltoroxp last edited by

                                Also das muss noch aktiv sein ?

                                aed4a185-71b0-4b98-8fab-9c21d91cab5b-grafik.png

                                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...

                                Homoran 1 Reply Last reply Reply Quote 0
                                • Homoran
                                  Homoran Global Moderator Administrators @D3ltoroxp last edited by

                                  @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

                                  1 Reply Last reply Reply Quote 0
                                  • OliverIO
                                    OliverIO last edited by

                                    @d3ltoroxp

                                    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?
                                    =1623241091971

                                    da 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.

                                    D3ltoroxp 1 Reply Last reply Reply Quote 0
                                    • D3ltoroxp
                                      D3ltoroxp @OliverIO last edited by D3ltoroxp

                                      @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.

                                      OliverIO P 2 Replies Last reply Reply Quote 0
                                      • OliverIO
                                        OliverIO @D3ltoroxp last edited by OliverIO

                                        @d3ltoroxp zeige mal das script, evtl sieht man da etwas.
                                        ich gehe mal davon aus, du bis in javascript nicht so gut?

                                        D3ltoroxp 1 Reply Last reply Reply Quote 0
                                        • D3ltoroxp
                                          D3ltoroxp @OliverIO last edited by

                                          @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...

                                          OliverIO 1 Reply Last reply Reply Quote 0
                                          • OliverIO
                                            OliverIO @D3ltoroxp last edited by

                                            @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.

                                            D3ltoroxp 1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            550
                                            Online

                                            31.9k
                                            Users

                                            80.1k
                                            Topics

                                            1.3m
                                            Posts

                                            14
                                            196
                                            16028
                                            Loading More Posts
                                            • Oldest to Newest
                                            • Newest to Oldest
                                            • Most Votes
                                            Reply
                                            • Reply as topic
                                            Log in to reply
                                            Community
                                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                            The ioBroker Community 2014-2023
                                            logo