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 @Homoran last edited by

      @homoran Also verstehen tu ich das dennoch nicht, diesen Quatsch macht Windows doch auch nicht. Aber naja ist halt so und ich kann mich auf die Anzeige nicht verlassen.

      a5bbb5b9-2078-48a9-ba5e-57c409e60ec7-grafik.png

      Hier zeigt er mir dann nicht den tatsächlichen Verbrauch an. Das sind ja dann die 1,4 free. Wäre schon sinnvoller wenn man den tatsächlichen Speicher sehen würde, dann sähe es nämlich auch entspannter aus, wenn dort steht 3,3GB von 6GB.

      Thomas Braun crunchip OliverIO 3 Replies Last reply Reply Quote 0
      • Thomas Braun
        Thomas Braun Most Active @D3ltoroxp last edited by

        @d3ltoroxp sagte in Ram läuft voll:

        diesen Quatsch macht Windows doch auch nicht.

        Die Speicherverwaltung läuft da auch in weiten Teilen anders ab. Quatsch ist der Linux-Ansatz aber eigentlich nicht. RAM ist schnell, warum soll man dann RAM nicht benutzen?

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

          @d3ltoroxp sagte in Ram läuft voll:

          diesen Quatsch macht Windows doch auch nich

          deswegeist es ja auch windoof.
          Linux verwaltet den RAM sinnvoller. schiebt ihn dahin, wo er am ehesten gebraucht werden könnte.
          Windoof versucht unnötigerweise möglichst viel RAM frei zuhalten. Wofür? nur genutzter RAM ist sinnvoller RAM.

          Hab gerade mal bei mir gesucht

          Screenshot_20220120-210615_Firefox.jpg

          am 15. 1. gabs einen reboot, RAM war frei.
          Dann fing Linux langsam an den RAM den Prozessen zuzuweisen.
          um 01:00 war backitup dran. Das braucht einiges an RAM. Linux schiebt alles verfügbare dahin.

          Anschließend wird nur noch ein unbedingt notwediges Minimum freigehalten, aber stabil

          bahnuhr 1 Reply Last reply Reply Quote 0
          • crunchip
            crunchip Forum Testing Most Active @D3ltoroxp last edited by

            @d3ltoroxp gib mal auf deinem host folgendes ein. Vmid steht für deine Vmnummer.
            Dann hast du alles aufgelistet, musst allerdings umrechnen

            qm status vmid --verbose
            

            https://pve.proxmox.com/pve-docs/qm.1.html

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

              @d3ltoroxp
              Windows macht das in ähnlicher Weise auch.
              Möglichst viel mit Reserven in Hauptspeicher. Swapfile, etc.

              1 Reply Last reply Reply Quote 0
              • bahnuhr
                bahnuhr Forum Testing Most Active @Homoran last edited by

                @homoran

                Rainer, was du denn da für eine schöne Grafik.
                Was ist input/output Counts?

                Kannst du diese mal zur Verfügung stellen?
                Danke.

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

                  @bahnuhr sagte in Ram läuft voll:

                  Was ist input/output Counts?

                  keine Ahnung!

                  Hab den Chart für alle Hosts gehabt, kam aber damals in der Proxmox VM nicht an CPU Temp und CPU Frequency. Da hab ich irgendwas genommen was gut klang und gehofft ich bekomme das noch raus.

                  Der chart ist ein einfacher flot iFrame

                  bahnuhr 1 Reply Last reply Reply Quote 0
                  • bahnuhr
                    bahnuhr Forum Testing Most Active @Homoran last edited by

                    @homoran sagte in Ram läuft voll:

                    Da hab ich irgendwas genommen was gut klang und gehofft ich bekomme das noch raus.

                    Der is gut 😉

                    Danke für die Info.

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

                      @crunchip Müsste ich wahrscheinlich was installieren, Kommando nicht gefunden.

                      crunchip 1 Reply Last reply Reply Quote 0
                      • crunchip
                        crunchip Forum Testing Most Active @D3ltoroxp last edited by crunchip

                        @d3ltoroxp sagte in Ram läuft voll:

                        @crunchip Müsste ich wahrscheinlich was installieren, Kommando nicht gefunden.

                        ??
                        was soll da installiert werden, du rufst die Details deiner VM vom Host aus auf
                        sieht dann so aus
                        18297515-ef45-486f-89e8-aa5375d926b4-grafik.png

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

                          Ich bin mir nicht sicher, den habe ich gestern aktiviert seitdem wieder diese Ram Überläufe, grad schon wieder... Ich habs wieder deaktiviert.

                          // 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 {
                                  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 2 Replies Last reply Reply Quote 0
                          • OliverIO
                            OliverIO @D3ltoroxp last edited by OliverIO

                            @d3ltoroxp
                            Grundsätzlich sehe ich ersteinmal keine Anhaltspunkt für ein speicherleck
                            Allerdings sehe ich ineffiziente Programmierung
                            Kannst du mal bitte ermitteln wieviel Objekte durch den selektor
                            In zeile 4 betroffen sind?
                            Immer wenn eine Änderung eines datenpunktes erfolgt wird ja
                            Dann ical2CalendarWidget aufgerufen.
                            Als parameter werden dann Details zum Status mit übergeben, was du aber nicht nutzt.
                            Trotzdem rechnest du die Details für alle datenpunkte durch.

                            Wenn die Anzahl der datenpunkte gering ist dürfte auch das kein Problem sein.
                            Wenn sie aber höher ist, und die Anzahl der Änderungen häufig, dann erfolgt da sehr viel rechenarbeit für unnötig Zuviel Daten.
                            Wenn du das optimierst, müsste sich das normalisieren.

                            D3ltoroxp 1 Reply Last reply Reply Quote 0
                            • 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
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            964
                                            Online

                                            31.9k
                                            Users

                                            80.1k
                                            Topics

                                            1.3m
                                            Posts

                                            14
                                            196
                                            16022
                                            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