Skip to content
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Default (No Skin)
  • No Skin
Collapse
Logo
  1. ioBroker Community Home
  2. Deutsch
  3. ioBroker Allgemein
  4. js-controller 4.0 jetzt im BETA/LATEST!

NEWS

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    8.0k

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    13
    1
    1.8k

  • Neues Video "KI im Smart Home" - ioBroker plus n8n
    BluefoxB
    Bluefox
    15
    1
    2.0k

js-controller 4.0 jetzt im BETA/LATEST!

js-controller 4.0 jetzt im BETA/LATEST!

Scheduled Pinned Locked Moved ioBroker Allgemein
747 Posts 70 Posters 223.9k Views 60 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • apollon77A apollon77

    @crunchip und welcher Prozess ist es? Vllt solltest du dich mal einige Host und Adapter States mit History mitloggen das du genauer sagen kannst was sich wann wie anders verhält.

    crunchipC Away
    crunchipC Away
    crunchip
    Forum Testing Most Active
    wrote on last edited by crunchip
    #416

    @apollon77 glaub ich hab das Problem schon gefunden, scheint an javascript zu liegen, bzw eher ein Script, das Wetterwarn Script https://forum.iobroker.net/topic/30616/script-dwd-uwz-nina-warnungen-als-push-sprachnachrichten/
    das war das einzige was ich die Tage aktualisiert hatte. Wenn ich das deaktiviere, geht die CPU runter
    Edit
    Bei der Javascript Instanz lagen die Ein/Ausgänge bei ~3500/~1000 nach dem iobroker gestartet wurde

    umgestiegen von Proxmox auf Unraid

    apollon77A 1 Reply Last reply
    0
    • crunchipC crunchip

      @apollon77 glaub ich hab das Problem schon gefunden, scheint an javascript zu liegen, bzw eher ein Script, das Wetterwarn Script https://forum.iobroker.net/topic/30616/script-dwd-uwz-nina-warnungen-als-push-sprachnachrichten/
      das war das einzige was ich die Tage aktualisiert hatte. Wenn ich das deaktiviere, geht die CPU runter
      Edit
      Bei der Javascript Instanz lagen die Ein/Ausgänge bei ~3500/~1000 nach dem iobroker gestartet wurde

      apollon77A Online
      apollon77A Online
      apollon77
      wrote on last edited by
      #417

      @crunchip ok. Na dann viel Spaß beim weiter forschen 😉

      Eingehend JavaScript ist immer seh hoch weil ja alles rein geht bei Standard Konfiguration. Aber 1000 ausgehende ist ne Menge 😉 (ist eine 15s Messung) 😉

      Beitrag hat geholfen? Votet rechts unten im Beitrag :-) https://paypal.me/Apollon77 / https://github.com/sponsors/Apollon77

      • Debug-Log für Instanz einschalten? Admin -> Instanzen -> Expertenmodus -> Instanz aufklappen - Loglevel ändern
      • Logfiles auf Platte /opt/iobroker/log/… nutzen, Admin schneidet Zeilen ab
      crunchipC 1 Reply Last reply
      0
      • apollon77A apollon77

        @crunchip ok. Na dann viel Spaß beim weiter forschen 😉

        Eingehend JavaScript ist immer seh hoch weil ja alles rein geht bei Standard Konfiguration. Aber 1000 ausgehende ist ne Menge 😉 (ist eine 15s Messung) 😉

        crunchipC Away
        crunchipC Away
        crunchip
        Forum Testing Most Active
        wrote on last edited by
        #418

        @apollon77 script ist in arbeit,
        wenns normal läuft liegt die Instanz im Schnitt bei 1000/14

        umgestiegen von Proxmox auf Unraid

        H 1 Reply Last reply
        0
        • crunchipC crunchip

          @apollon77 script ist in arbeit,
          wenns normal läuft liegt die Instanz im Schnitt bei 1000/14

          H Offline
          H Offline
          homecineplexx
          wrote on last edited by
          #419

          @crunchip said in js-controller 4.0 jetzt im BETA/LATEST!:

          @apollon77 script ist in arbeit,
          wenns normal läuft liegt die Instanz im Schnitt bei 1000/14

          ich hab 3 JavaScript Instanzen. bei 2 davon geb ich dir recht mit
          -) 5680/11
          -) 5702/11
          aber bei der dritten
          -) 5386/2642

          apollon77A 1 Reply Last reply
          0
          • AlCalzoneA AlCalzone

            @diginix sagte in js-controller 4.0 jetzt im BETA/LATEST!:

            Alle in/out aller 47 Instanzen ging als Screenshot am einfachsten:
            https://www.dropbox.com/s/ceafuk51rhv0om2/2022-02-17_in_out_adapter.png?dl=0

            Auf der Instanzübersicht wärs etwas kompakter gewesen 🙂
            a7c9f02d-8c0a-4127-a87e-df96be6936f1-grafik.png

            Naja gut, sieht jetzt aber nicht überlastet aus... Bin mal auf den RAM gespannt.

            DiginixD Offline
            DiginixD Offline
            Diginix
            wrote on last edited by Diginix
            #420

            @alcalzone sagte in js-controller 4.0 jetzt im BETA/LATEST!:

            Naja gut, sieht jetzt aber nicht überlastet aus... Bin mal auf den RAM gespannt.

            iobroker start nach js-controller Update auf 4.0.12. Wobei die Ver. wahrs. egal ist. Aber der js-controller nimmt sich da fast 3min 2 GB RAM. Da ist klar warum der bei sonst <1GB freien RAM der VM vom OOM abgeschossen wurde.

            2148a627-6f70-4452-8652-513b353b5361-image.png

            States in/out ist dabei unspektakulär.

            ..:: So long! Tom ::..

            NUC7i3 (Ubuntu Proxmox VM) | Echo Dots 2+3. Gen | Xiaomi Sensoren | Mi Robot 1S | Yeelight | Sonoff | Shelly | H801 RGB | Gosund SP1 | NodeMCU+ESP32 | Kostal Plenticore PV+BYD | openWB

            AlCalzoneA apollon77A 2 Replies Last reply
            0
            • H homecineplexx

              @crunchip said in js-controller 4.0 jetzt im BETA/LATEST!:

              @apollon77 script ist in arbeit,
              wenns normal läuft liegt die Instanz im Schnitt bei 1000/14

              ich hab 3 JavaScript Instanzen. bei 2 davon geb ich dir recht mit
              -) 5680/11
              -) 5702/11
              aber bei der dritten
              -) 5386/2642

              apollon77A Online
              apollon77A Online
              apollon77
              wrote on last edited by
              #421

              @homecineplexx sagte in js-controller 4.0 jetzt im BETA/LATEST!:

              -) 5386/2642

              Naja dann hast Du in der dritten ein Skript laufen was sehr viele "setState" oder andere Aktionen macht ... Wenn das so soll ist ja alles in Ordnung 🙂

              Beitrag hat geholfen? Votet rechts unten im Beitrag :-) https://paypal.me/Apollon77 / https://github.com/sponsors/Apollon77

              • Debug-Log für Instanz einschalten? Admin -> Instanzen -> Expertenmodus -> Instanz aufklappen - Loglevel ändern
              • Logfiles auf Platte /opt/iobroker/log/… nutzen, Admin schneidet Zeilen ab
              H 1 Reply Last reply
              0
              • DiginixD Diginix

                @alcalzone sagte in js-controller 4.0 jetzt im BETA/LATEST!:

                Naja gut, sieht jetzt aber nicht überlastet aus... Bin mal auf den RAM gespannt.

                iobroker start nach js-controller Update auf 4.0.12. Wobei die Ver. wahrs. egal ist. Aber der js-controller nimmt sich da fast 3min 2 GB RAM. Da ist klar warum der bei sonst <1GB freien RAM der VM vom OOM abgeschossen wurde.

                2148a627-6f70-4452-8652-513b353b5361-image.png

                States in/out ist dabei unspektakulär.

                AlCalzoneA Offline
                AlCalzoneA Offline
                AlCalzone
                Developer
                wrote on last edited by
                #422

                @diginix sagte in js-controller 4.0 jetzt im BETA/LATEST!:

                iobroker start nach js-controller Update auf 4.0.12. Wobei die Ver. wahrs. egal ist. Aber der js-controller nimmt sich da fast 3min 2 GB RAM. Da ist klar warum der bei sonst <1GB freien RAM der VM vom OOM abgeschossen wurde.

                D.h. der Peak ist der Controller-Start? Wenn ja, magst du mir mal deine objects.jsonl, states.jsonl und iobroker.json schicken, dass ich das nachstellen kann? Schick dir nen Upload-Link per PN.

                Warum `sudo` böse ist: https://forum.iobroker.net/post/17109

                DiginixD 1 Reply Last reply
                0
                • DiginixD Diginix

                  @alcalzone sagte in js-controller 4.0 jetzt im BETA/LATEST!:

                  Naja gut, sieht jetzt aber nicht überlastet aus... Bin mal auf den RAM gespannt.

                  iobroker start nach js-controller Update auf 4.0.12. Wobei die Ver. wahrs. egal ist. Aber der js-controller nimmt sich da fast 3min 2 GB RAM. Da ist klar warum der bei sonst <1GB freien RAM der VM vom OOM abgeschossen wurde.

                  2148a627-6f70-4452-8652-513b353b5361-image.png

                  States in/out ist dabei unspektakulär.

                  apollon77A Online
                  apollon77A Online
                  apollon77
                  wrote on last edited by
                  #423

                  @diginix Hm ... Was war denn in dem Zeitraum? Ist das ein Start oder zwischendrin? Ein Backup? Oder was ist da gewesen? Habe solche "Ausschläge" noch nie gesehen 🙂

                  Beitrag hat geholfen? Votet rechts unten im Beitrag :-) https://paypal.me/Apollon77 / https://github.com/sponsors/Apollon77

                  • Debug-Log für Instanz einschalten? Admin -> Instanzen -> Expertenmodus -> Instanz aufklappen - Loglevel ändern
                  • Logfiles auf Platte /opt/iobroker/log/… nutzen, Admin schneidet Zeilen ab
                  1 Reply Last reply
                  0
                  • AlCalzoneA AlCalzone

                    @diginix sagte in js-controller 4.0 jetzt im BETA/LATEST!:

                    iobroker start nach js-controller Update auf 4.0.12. Wobei die Ver. wahrs. egal ist. Aber der js-controller nimmt sich da fast 3min 2 GB RAM. Da ist klar warum der bei sonst <1GB freien RAM der VM vom OOM abgeschossen wurde.

                    D.h. der Peak ist der Controller-Start? Wenn ja, magst du mir mal deine objects.jsonl, states.jsonl und iobroker.json schicken, dass ich das nachstellen kann? Schick dir nen Upload-Link per PN.

                    DiginixD Offline
                    DiginixD Offline
                    Diginix
                    wrote on last edited by
                    #424

                    @alcalzone sagte in js-controller 4.0 jetzt im BETA/LATEST!:

                    @diginix sagte in js-controller 4.0 jetzt im BETA/LATEST!:

                    iobroker start nach js-controller Update auf 4.0.12. Wobei die Ver. wahrs. egal ist. Aber der js-controller nimmt sich da fast 3min 2 GB RAM. Da ist klar warum der bei sonst <1GB freien RAM der VM vom OOM abgeschossen wurde.

                    D.h. der Peak ist der Controller-Start? Wenn ja, magst du mir mal deine objects.jsonl, states.jsonl und iobroker.json schicken, dass ich das nachstellen kann? Schick dir nen Upload-Link per PN.

                    Ja der peak war bei/ab "iobroker start" nach dem js-controller Update auf 4.0.12.

                    Dateien sende ich dir.

                    ..:: So long! Tom ::..

                    NUC7i3 (Ubuntu Proxmox VM) | Echo Dots 2+3. Gen | Xiaomi Sensoren | Mi Robot 1S | Yeelight | Sonoff | Shelly | H801 RGB | Gosund SP1 | NodeMCU+ESP32 | Kostal Plenticore PV+BYD | openWB

                    apollon77A 1 Reply Last reply
                    1
                    • DiginixD Diginix

                      @alcalzone sagte in js-controller 4.0 jetzt im BETA/LATEST!:

                      @diginix sagte in js-controller 4.0 jetzt im BETA/LATEST!:

                      iobroker start nach js-controller Update auf 4.0.12. Wobei die Ver. wahrs. egal ist. Aber der js-controller nimmt sich da fast 3min 2 GB RAM. Da ist klar warum der bei sonst <1GB freien RAM der VM vom OOM abgeschossen wurde.

                      D.h. der Peak ist der Controller-Start? Wenn ja, magst du mir mal deine objects.jsonl, states.jsonl und iobroker.json schicken, dass ich das nachstellen kann? Schick dir nen Upload-Link per PN.

                      Ja der peak war bei/ab "iobroker start" nach dem js-controller Update auf 4.0.12.

                      Dateien sende ich dir.

                      apollon77A Online
                      apollon77A Online
                      apollon77
                      wrote on last edited by
                      #425

                      @diginix Kannst Du denn Peak mit einem einfachen "neuen" Start reproduzieren?

                      Beitrag hat geholfen? Votet rechts unten im Beitrag :-) https://paypal.me/Apollon77 / https://github.com/sponsors/Apollon77

                      • Debug-Log für Instanz einschalten? Admin -> Instanzen -> Expertenmodus -> Instanz aufklappen - Loglevel ändern
                      • Logfiles auf Platte /opt/iobroker/log/… nutzen, Admin schneidet Zeilen ab
                      DiginixD 1 Reply Last reply
                      0
                      • apollon77A apollon77

                        @homecineplexx sagte in js-controller 4.0 jetzt im BETA/LATEST!:

                        -) 5386/2642

                        Naja dann hast Du in der dritten ein Skript laufen was sehr viele "setState" oder andere Aktionen macht ... Wenn das so soll ist ja alles in Ordnung 🙂

                        H Offline
                        H Offline
                        homecineplexx
                        wrote on last edited by
                        #426

                        @apollon77 said in js-controller 4.0 jetzt im BETA/LATEST!:

                        @homecineplexx sagte in js-controller 4.0 jetzt im BETA/LATEST!:

                        -) 5386/2642

                        Naja dann hast Du in der dritten ein Skript laufen was sehr viele "setState" oder andere Aktionen macht ... Wenn das so soll ist ja alles in Ordnung 🙂

                        ich hab hier einfach viele solcher Skripte am laufen, die mir quasi einen Alias machen und bissl mehr noch.
                        Vielleicht könnte man diese ja auch vereinfachen...?

                        var preNameSpace = 'VirtualDevice.0.';
                        
                        //generic virtual device        
                        function VirtualDevice(config) {
                            //sanity check
                            if (typeof config !== 'object' || typeof config.namespace !== 'string' || typeof config.name !== 'string' || typeof config.states !== 'object') {
                                log('sanity check failed, no device created', 'warn');
                                return;
                            }
                         
                            this.config = config;
                            this.namespace = preNameSpace + config.namespace + '.' + config.name;
                            this.name = config.name;
                         
                            //create virtual device
                            log('creating virtual device ' + this.namespace);
                            this.createDevice(function () {
                                this.createStates(function () {
                                    log('created virtual device ' + this.namespace);
                                }.bind(this));
                            }.bind(this));
                        }
                         
                        VirtualDevice.prototype.createDevice = function (callback) {
                            log('creating object for device ' + this.namespace, 'debug');
                            //create device object
                            var obj = this.config.copy ? getObject(this.config.copy) : {common: {}, native: {}};
                            delete obj.common.custom;
                            if (typeof this.config.common === 'object') {
                                obj.common = Object.assign(obj.common, this.config.common);
                            }
                            if (typeof this.config.native === 'object') {
                                obj.native = Object.assign(obj.native, this.config.native);
                            }
                            extendObject(this.namespace, {
                                //type: "device",
                                type: "channel",
                                common: obj.common,
                                native: obj.native
                            }, function (err) {
                                if (err) {
                                    log('could not create virtual device: ' + this.namespace, 'warn');
                                    return;
                                }
                                log('created object for device ' + this.namespace, 'debug');
                                if (typeof this.config.onCreate === 'function') {
                                    this.config.onCreate(this, callback);
                                } else {
                                    callback();
                                }
                            }.bind(this));
                        };
                          
                        VirtualDevice.prototype.createStates = function (callback) {
                            "use strict";
                            log('creating states for device ' + this.namespace, 'debug');
                            var stateIds = Object.keys(this.config.states);
                            log('creating states ' + JSON.stringify(stateIds), 'debug');
                            var countCreated = 0;
                            for (var i = 0; i < stateIds.length; i++) {
                                let stateId = stateIds[i];
                                this.normalizeState(stateId);
                                var id = this.namespace + '.' + stateId;
                                log('creating state ' + id, 'debug');
                                var obj = this.config.states[stateId].copy ? getObject(this.config.states[stateId].copy) : {
                                    type: "state",
                                    common: {},
                                    native: {}
                                };
                                delete obj.common.custom;
                                if (typeof this.config.states[stateId].common === 'object') {
                                    obj.common = Object.assign(obj.common, this.config.states[stateId].common);
                                }
                                if (typeof this.config.states[stateId].native === 'object') {
                                    obj.native = Object.assign(obj.native, this.config.states[stateId].native);
                                }
                        
                        		setObject(id, obj, function(err, checkObj) {
                        			if (err) {
                                        log('skipping creation of state ' + id, 'debug');
                                    } else {
                                        log('created state ' + id, 'debug');
                                    }
                                    if (!err && checkObj) {
                                        //setTimeout(function(){
                                            this.connectState(stateId);
                                            countCreated++;
                                            if (countCreated >= stateIds.length) {
                                                log('created ' + countCreated + ' states for device ' + this.namespace, 'debug');
                                                callback();
                                            }
                        
                                            var newId = checkObj.id;
                                            var helper = newId.substr(newId.lastIndexOf('.') + 1, newId.length);
                                            
                                            var stateValueNew = this.config.states[helper].stateValue;
                                            
                                            if (stateValueNew !== undefined) {
                                                setStateDelayed(newId, stateValueNew, true, 1000);
                                                log('set default: ' + stateValueNew + ' for ' + newId);
                                            }
                                        //}.bind(this), 500);
                                    }
                        		}.bind(this)); 
                            }
                        };
                         
                        VirtualDevice.prototype.normalizeState = function (state) {
                            log('normalizing state ' + state, 'debug');
                            if (typeof this.config.states[state].read !== 'object') {
                                this.config.states[state].read = {};
                            }
                            if (typeof this.config.states[state].write !== 'object') {
                                this.config.states[state].write = {};
                            }
                         
                            var readIds = Object.keys(this.config.states[state].read);
                            for (var i = 0; i < readIds.length; i++) {
                                var readId = this.config.states[state].read[readIds[i]];
                                if (typeof readId.before !== 'function') {
                                    this.config.states[state].read[readIds[i]].before = function (device, value, callback) {
                                        callback();
                                    };
                                }
                                if (typeof readId.after !== 'function') {
                                    this.config.states[state].read[readIds[i]].after = function (device, value) {
                                    };
                                }
                            }
                            var writeIds = Object.keys(this.config.states[state].write);
                            for (i = 0; i < writeIds.length; i++) {
                                var writeId = this.config.states[state].write[writeIds[i]];
                                if (typeof writeId.before !== 'function') {
                                    this.config.states[state].write[writeIds[i]].before = function (device, value, callback) {
                                        callback()
                                    };
                                }
                                if (typeof writeId.after !== 'function') {
                                    this.config.states[state].write[writeIds[i]].after = function (device, value) {
                                    };
                                }
                            }
                            log('normalized state ' + state, 'debug');
                        };
                         
                        
                        VirtualDevice.prototype.connectState = function (state) {
                            setTimeout(function(){
                                log('connecting state ' + state, 'debug');
                                var id = this.namespace + '.' + state;
                            
                                //subscribe to read ids
                                var readIds = Object.keys(this.config.states[state].read);
                                for (var i = 0; i < readIds.length; i++) {
                                    if (readIds[i] === null || readIds[i] === undefined || readIds[i] === '') {
                                        continue;
                                    }
                                    if (getState(readIds[i]).notExist === true) { //check if state exists
                                        log('cannot connect to not existing state: ' + readIds[i], 'warn');
                                        continue;
                                    }
                                    var readObj = this.config.states[state].read[readIds[i]];
                                    var trigger = readObj.trigger || {change: 'any'};
                                    trigger.ack = true;
                                    trigger.id = readIds[i];
                                    this.subRead(trigger, readObj, state);
                                    log('connected ' + readIds[i] + ' to ' + id, 'debug');
                                }
                            
                                //subscribe to this state and write to write ids
                                var writeIds = Object.keys(this.config.states[state].write);
                                var trigger = {id: this.namespace + '.' + state, change: 'any', ack: false};
                        
                                on(trigger, function (obj) {
                                    "use strict";
                                    log('detected change of ' + state, 'debug');
                                    for (var i = 0; i < writeIds.length; i++) {
                                        let writeObj = this.config.states[state].write[writeIds[i]];
                                        let val = this.convertValue(obj.state.val, writeObj.convert);
                                        let writeId = writeIds[i];
                                        log('executing function before for ' + writeId, 'debug');
                                        writeObj.before(this, val, function (newVal, newDelay) {
                                            if (newVal !== undefined && newVal !== null) val = newVal;
                                            var delay = writeObj.delay;
                                            if (newDelay !== undefined && newDelay !== null) delay = newDelay;
                                            log(newVal + 'writing value ' + val + ' to ' + writeId + ' with delay ' + delay, 'debug');
                                            setStateDelayed(writeId, val, false, delay || 0, true, function () {
                                                log('executing function after for ' + writeId, 'debug');
                                                writeObj.after(this, val);
                                            }.bind(this));
                                        }.bind(this));
                                    }
                                }.bind(this));
                        
                                log('connected ' + state + ' to ' + JSON.stringify(writeIds), 'debug');
                            }.bind(this), 500);
                        };
                          
                        VirtualDevice.prototype.subRead = function (trigger, readObj, state) {
                            var func = function (obj) {
                                var val = this.convertValue(obj.state.val, readObj.convert);
                         
                                log('executing function before for ' + trigger.id, 'debug');
                                readObj.before(this, val, function (newVal, newDelay) {
                                    if (newVal !== undefined && newVal !== null) val = newVal;
                                    if (newDelay !== undefined && newDelay !== null) writeObj.delay = newDelay;
                                    log('reading value ' + val + ' to ' + this.namespace + '.' + state, 'debug');
                                    setStateDelayed(this.namespace + '.' + state, val, true, readObj.delay || 0, true, function () {
                                        log('executing function after for ' + trigger.id, 'debug');
                                        readObj.after(this, val);
                                    }.bind(this));
                                }.bind(this));
                            }.bind(this);
                            func({state: getState(trigger.id)});
                            on(trigger, func);
                        };
                         
                        VirtualDevice.prototype.convertValue = function (val, func) {
                            if (typeof func !== 'function') {
                                return val;
                            }
                            return func(val);
                        };
                        
                        var deviceId = 'Deckenlicht';
                        var namespace = 'Ankleide';
                        var path = preNameSpace + namespace + '.' + deviceId;
                        
                        new VirtualDevice({
                            namespace: namespace,
                            name: deviceId,
                            states: {
                                'name': {
                                    common: {name: 'name', role: 'text', type: 'string', desc: 'name', read: true, write: false, def: namespace + ' - ' + deviceId},
                                    stateValue: namespace + ' - ' + deviceId
                                },
                                'isTelegramInfo': {
                                    common: {name: 'TelegramInfo wird durch JavaScript gesetzt', role: 'state', type: 'boolean', desc: 'TelegramInfo', read: true, write: true, def: true},
                                    stateValue: true
                                },
                                'isTelegramInfoSwitch': {
                                    common: {name: 'TelegramInfo wird durch JavaScript gesetzt', role: 'state', type: 'boolean', desc: 'TelegramInfo', read: true, write: true, def: true},
                                    stateValue: true
                                },
                                'switch': {
                                    common: {name: 'switch', role: 'switch', type: 'boolean', desc: 'switch', def: false, read: true, write: true,
                                        custom: {
                                            'influxdb.0': {
                                                'enabled': true,
                                                'changesOnly': true,
                                                'debounce': 0,
                                                'maxLength': 10,
                                                'retention': 0,
                                                'changesRelogInterval': 30,
                                                'changesMinDelta': 0,
                                                'storageType': '',
                                                'aliasId': ''
                                            }
                                        }
                                    },
                                    read: {
                                        'mqtt.0.shellies.shelly1-555EDB.relay.0': {
                                            convert: function (val) {
                                                if (val == 'on') {
                                                    val = true;
                                                } else {
                                                    val = false;
                                                }
                                                return val;
                                            },
                                            trigger: setTimeout(function(){
                                                        on({id:path + '.switch', change: 'ne'}, function (obj) {
                                                            if (getState(path + '.isTelegramInfoSwitch').val === true) {
                                                                var value = obj.state.val;
                                                                var name = getState(path + '.name').val;
                        
                                                                _sendLogToTelegram(_findCorrectEmoji(name + ' wurde ' + (value === true ? 'eingeschaltet.' : 'ausgeschaltet.')));
                                                            } 
                                                        })
                                                    }, 500)
                                        },
                                    },
                                    write: {
                                        'mqtt.0.shellies.shelly1-555EDB.relay.0.command': {
                                            convert: function (val) {
                                                if (val === true) {
                                                    val ='on';
                                                } else {
                                                    val = 'off';
                                                }
                                                return val;
                                            },
                                        },
                                    }
                                },
                                'online': {
                                    common: {name: 'online', role: 'variable', type: 'boolean', desc: 'online', read: true, write: false, def: false,
                                        custom: {
                                            'influxdb.0': {
                                                'enabled': true,
                                                'changesOnly': true,
                                                'debounce': 0,
                                                'maxLength': 10,
                                                'retention': 0,
                                                'changesRelogInterval': 30,
                                                'changesMinDelta': 0,
                                                'storageType': '',
                                                'aliasId': ''
                                            }
                                        }
                                    },
                                    read: {
                                        'mqtt.0.shellies.shelly1-555EDB.online': {
                                            trigger: setTimeout(function(){
                                                    on({id:path + '.online', change: 'ne'}, function (obj) {
                                                        var value = obj.state.val;
                        
                                                        if (value === false) {
                                                            setState('AllOwnCreated.0.shelly.isWrongState', true);
                                                        }
                        
                                                        if (getState(path + '.isTelegramInfo').val === true) {
                                                            var name = getState(path + '.name').val;
                        
                                                            _sendLogToTelegram(_findCorrectEmoji('OnlineStatus: ' + name + ' ist ' + (value === true ? 'wieder' : 'nicht') + ' erreichbar.'));
                                                        } 
                                                    })
                                                }, 500)
                                        },
                                    },
                                    write: {}
                                },
                                'command': {
                                    common: {name: 'command', role: 'variable',  type: 'string', desc: 'command', read: true, write: true, def: ''},
                                    read: {
                                        'mqtt.0.shellies.shelly1-555EDB.command': {},
                                    },
                                    write: {
                                        'mqtt.0.shellies.shelly1-555EDB.command': {
                                        },
                                    }
                                },
                                'announce': {
                                    common: {name: 'announce', role: 'variable',  type: 'string', desc: 'announce', read: true, write: false, def: ''},
                                    read: {
                                        'mqtt.0.shellies.shelly1-555EDB.announce': {
                                            convert: function (val) {
                                               var jsonValue = JSON.parse(val);
                                               
                                                calculateJson(jsonValue, 'Info');
                        
                                                return val;
                                            },
                                        },
                                    },
                                },
                                'info': {
                                    common: {name: 'info', role: 'variable',  type: 'string', desc: 'info', read: true, write: false, def: ''},
                                    read: {
                                        'mqtt.0.shellies.shelly1-555EDB.info': {},
                                    },
                                },      
                            }
                        }); 
                        
                        function calculateJson(jsonValue, subFolder) {
                            for (var key in jsonValue) {
                                if (jsonValue.hasOwnProperty(key)) {
                                    try {  
                                        var jsonNewValue = JSON.parse(jsonValue[key]);  
                        
                                        calculateJson(jsonNewValue)
                                    } catch (e) {
                                        if (typeof jsonValue[key] == 'object') {
                                            for (var item in jsonValue[key]) {
                                                //var commonType = getCommonType(item);
                                                var commonType = null;
                                                doCreateStates(path + '.' + subFolder +'.' + item, item, jsonValue[key][item], commonType) 
                                            }
                                        } else {
                                            doCreateStates(path + '.' + subFolder + '.' + key, key, jsonValue[key])    
                                        }    
                                    }
                                }
                            }
                        }
                        
                        function doCreateStates(newObject, name, value, commonType) {
                            var obj = getObject(newObject);
                        
                            if (commonType == undefined) {
                                commonType = {'name': name, 'role': 'state', 'type': 'string', desc: name, read: true, write: false, def: ''};
                            }
                        
                            if (commonType['type'] == 'number') {
                                
                            } else {
                                value = '' + value;
                            }
                        
                        	if (!obj) {
                        		setObject(newObject, {
                        			type: 'state',
                        			common: commonType,
                        			native: {}
                        		}, function(err, obj) {
                        			if (!err && obj) {
                        				console.log('Object for ' + obj.id + ' created');
                                        setState(newObject, value, true);
                        			}
                        		});
                        	} else {
                                setState(newObject, value, true);    
                            }
                        
                            if (name == 'LWT') {
                                setTimeout(function() {
                                    on({id:newObject, change: 'ne'}, function (obj) {
                                        if (getState(path + '.isTelegramInfo').val === true) {
                                            var value = obj.state.val;
                                            var name = getState(path + '.name').val;
                        
                                            _sendLogToTelegram(_findCorrectEmoji(name + ' wurde neu gestartet. Grund: ' + value));
                                        } 
                                    })
                                }, 500)    
                            }
                        }
                        
                        
                        
                        
                        apollon77A 1 Reply Last reply
                        0
                        • H homecineplexx

                          @apollon77 said in js-controller 4.0 jetzt im BETA/LATEST!:

                          @homecineplexx sagte in js-controller 4.0 jetzt im BETA/LATEST!:

                          -) 5386/2642

                          Naja dann hast Du in der dritten ein Skript laufen was sehr viele "setState" oder andere Aktionen macht ... Wenn das so soll ist ja alles in Ordnung 🙂

                          ich hab hier einfach viele solcher Skripte am laufen, die mir quasi einen Alias machen und bissl mehr noch.
                          Vielleicht könnte man diese ja auch vereinfachen...?

                          var preNameSpace = 'VirtualDevice.0.';
                          
                          //generic virtual device        
                          function VirtualDevice(config) {
                              //sanity check
                              if (typeof config !== 'object' || typeof config.namespace !== 'string' || typeof config.name !== 'string' || typeof config.states !== 'object') {
                                  log('sanity check failed, no device created', 'warn');
                                  return;
                              }
                           
                              this.config = config;
                              this.namespace = preNameSpace + config.namespace + '.' + config.name;
                              this.name = config.name;
                           
                              //create virtual device
                              log('creating virtual device ' + this.namespace);
                              this.createDevice(function () {
                                  this.createStates(function () {
                                      log('created virtual device ' + this.namespace);
                                  }.bind(this));
                              }.bind(this));
                          }
                           
                          VirtualDevice.prototype.createDevice = function (callback) {
                              log('creating object for device ' + this.namespace, 'debug');
                              //create device object
                              var obj = this.config.copy ? getObject(this.config.copy) : {common: {}, native: {}};
                              delete obj.common.custom;
                              if (typeof this.config.common === 'object') {
                                  obj.common = Object.assign(obj.common, this.config.common);
                              }
                              if (typeof this.config.native === 'object') {
                                  obj.native = Object.assign(obj.native, this.config.native);
                              }
                              extendObject(this.namespace, {
                                  //type: "device",
                                  type: "channel",
                                  common: obj.common,
                                  native: obj.native
                              }, function (err) {
                                  if (err) {
                                      log('could not create virtual device: ' + this.namespace, 'warn');
                                      return;
                                  }
                                  log('created object for device ' + this.namespace, 'debug');
                                  if (typeof this.config.onCreate === 'function') {
                                      this.config.onCreate(this, callback);
                                  } else {
                                      callback();
                                  }
                              }.bind(this));
                          };
                            
                          VirtualDevice.prototype.createStates = function (callback) {
                              "use strict";
                              log('creating states for device ' + this.namespace, 'debug');
                              var stateIds = Object.keys(this.config.states);
                              log('creating states ' + JSON.stringify(stateIds), 'debug');
                              var countCreated = 0;
                              for (var i = 0; i < stateIds.length; i++) {
                                  let stateId = stateIds[i];
                                  this.normalizeState(stateId);
                                  var id = this.namespace + '.' + stateId;
                                  log('creating state ' + id, 'debug');
                                  var obj = this.config.states[stateId].copy ? getObject(this.config.states[stateId].copy) : {
                                      type: "state",
                                      common: {},
                                      native: {}
                                  };
                                  delete obj.common.custom;
                                  if (typeof this.config.states[stateId].common === 'object') {
                                      obj.common = Object.assign(obj.common, this.config.states[stateId].common);
                                  }
                                  if (typeof this.config.states[stateId].native === 'object') {
                                      obj.native = Object.assign(obj.native, this.config.states[stateId].native);
                                  }
                          
                          		setObject(id, obj, function(err, checkObj) {
                          			if (err) {
                                          log('skipping creation of state ' + id, 'debug');
                                      } else {
                                          log('created state ' + id, 'debug');
                                      }
                                      if (!err && checkObj) {
                                          //setTimeout(function(){
                                              this.connectState(stateId);
                                              countCreated++;
                                              if (countCreated >= stateIds.length) {
                                                  log('created ' + countCreated + ' states for device ' + this.namespace, 'debug');
                                                  callback();
                                              }
                          
                                              var newId = checkObj.id;
                                              var helper = newId.substr(newId.lastIndexOf('.') + 1, newId.length);
                                              
                                              var stateValueNew = this.config.states[helper].stateValue;
                                              
                                              if (stateValueNew !== undefined) {
                                                  setStateDelayed(newId, stateValueNew, true, 1000);
                                                  log('set default: ' + stateValueNew + ' for ' + newId);
                                              }
                                          //}.bind(this), 500);
                                      }
                          		}.bind(this)); 
                              }
                          };
                           
                          VirtualDevice.prototype.normalizeState = function (state) {
                              log('normalizing state ' + state, 'debug');
                              if (typeof this.config.states[state].read !== 'object') {
                                  this.config.states[state].read = {};
                              }
                              if (typeof this.config.states[state].write !== 'object') {
                                  this.config.states[state].write = {};
                              }
                           
                              var readIds = Object.keys(this.config.states[state].read);
                              for (var i = 0; i < readIds.length; i++) {
                                  var readId = this.config.states[state].read[readIds[i]];
                                  if (typeof readId.before !== 'function') {
                                      this.config.states[state].read[readIds[i]].before = function (device, value, callback) {
                                          callback();
                                      };
                                  }
                                  if (typeof readId.after !== 'function') {
                                      this.config.states[state].read[readIds[i]].after = function (device, value) {
                                      };
                                  }
                              }
                              var writeIds = Object.keys(this.config.states[state].write);
                              for (i = 0; i < writeIds.length; i++) {
                                  var writeId = this.config.states[state].write[writeIds[i]];
                                  if (typeof writeId.before !== 'function') {
                                      this.config.states[state].write[writeIds[i]].before = function (device, value, callback) {
                                          callback()
                                      };
                                  }
                                  if (typeof writeId.after !== 'function') {
                                      this.config.states[state].write[writeIds[i]].after = function (device, value) {
                                      };
                                  }
                              }
                              log('normalized state ' + state, 'debug');
                          };
                           
                          
                          VirtualDevice.prototype.connectState = function (state) {
                              setTimeout(function(){
                                  log('connecting state ' + state, 'debug');
                                  var id = this.namespace + '.' + state;
                              
                                  //subscribe to read ids
                                  var readIds = Object.keys(this.config.states[state].read);
                                  for (var i = 0; i < readIds.length; i++) {
                                      if (readIds[i] === null || readIds[i] === undefined || readIds[i] === '') {
                                          continue;
                                      }
                                      if (getState(readIds[i]).notExist === true) { //check if state exists
                                          log('cannot connect to not existing state: ' + readIds[i], 'warn');
                                          continue;
                                      }
                                      var readObj = this.config.states[state].read[readIds[i]];
                                      var trigger = readObj.trigger || {change: 'any'};
                                      trigger.ack = true;
                                      trigger.id = readIds[i];
                                      this.subRead(trigger, readObj, state);
                                      log('connected ' + readIds[i] + ' to ' + id, 'debug');
                                  }
                              
                                  //subscribe to this state and write to write ids
                                  var writeIds = Object.keys(this.config.states[state].write);
                                  var trigger = {id: this.namespace + '.' + state, change: 'any', ack: false};
                          
                                  on(trigger, function (obj) {
                                      "use strict";
                                      log('detected change of ' + state, 'debug');
                                      for (var i = 0; i < writeIds.length; i++) {
                                          let writeObj = this.config.states[state].write[writeIds[i]];
                                          let val = this.convertValue(obj.state.val, writeObj.convert);
                                          let writeId = writeIds[i];
                                          log('executing function before for ' + writeId, 'debug');
                                          writeObj.before(this, val, function (newVal, newDelay) {
                                              if (newVal !== undefined && newVal !== null) val = newVal;
                                              var delay = writeObj.delay;
                                              if (newDelay !== undefined && newDelay !== null) delay = newDelay;
                                              log(newVal + 'writing value ' + val + ' to ' + writeId + ' with delay ' + delay, 'debug');
                                              setStateDelayed(writeId, val, false, delay || 0, true, function () {
                                                  log('executing function after for ' + writeId, 'debug');
                                                  writeObj.after(this, val);
                                              }.bind(this));
                                          }.bind(this));
                                      }
                                  }.bind(this));
                          
                                  log('connected ' + state + ' to ' + JSON.stringify(writeIds), 'debug');
                              }.bind(this), 500);
                          };
                            
                          VirtualDevice.prototype.subRead = function (trigger, readObj, state) {
                              var func = function (obj) {
                                  var val = this.convertValue(obj.state.val, readObj.convert);
                           
                                  log('executing function before for ' + trigger.id, 'debug');
                                  readObj.before(this, val, function (newVal, newDelay) {
                                      if (newVal !== undefined && newVal !== null) val = newVal;
                                      if (newDelay !== undefined && newDelay !== null) writeObj.delay = newDelay;
                                      log('reading value ' + val + ' to ' + this.namespace + '.' + state, 'debug');
                                      setStateDelayed(this.namespace + '.' + state, val, true, readObj.delay || 0, true, function () {
                                          log('executing function after for ' + trigger.id, 'debug');
                                          readObj.after(this, val);
                                      }.bind(this));
                                  }.bind(this));
                              }.bind(this);
                              func({state: getState(trigger.id)});
                              on(trigger, func);
                          };
                           
                          VirtualDevice.prototype.convertValue = function (val, func) {
                              if (typeof func !== 'function') {
                                  return val;
                              }
                              return func(val);
                          };
                          
                          var deviceId = 'Deckenlicht';
                          var namespace = 'Ankleide';
                          var path = preNameSpace + namespace + '.' + deviceId;
                          
                          new VirtualDevice({
                              namespace: namespace,
                              name: deviceId,
                              states: {
                                  'name': {
                                      common: {name: 'name', role: 'text', type: 'string', desc: 'name', read: true, write: false, def: namespace + ' - ' + deviceId},
                                      stateValue: namespace + ' - ' + deviceId
                                  },
                                  'isTelegramInfo': {
                                      common: {name: 'TelegramInfo wird durch JavaScript gesetzt', role: 'state', type: 'boolean', desc: 'TelegramInfo', read: true, write: true, def: true},
                                      stateValue: true
                                  },
                                  'isTelegramInfoSwitch': {
                                      common: {name: 'TelegramInfo wird durch JavaScript gesetzt', role: 'state', type: 'boolean', desc: 'TelegramInfo', read: true, write: true, def: true},
                                      stateValue: true
                                  },
                                  'switch': {
                                      common: {name: 'switch', role: 'switch', type: 'boolean', desc: 'switch', def: false, read: true, write: true,
                                          custom: {
                                              'influxdb.0': {
                                                  'enabled': true,
                                                  'changesOnly': true,
                                                  'debounce': 0,
                                                  'maxLength': 10,
                                                  'retention': 0,
                                                  'changesRelogInterval': 30,
                                                  'changesMinDelta': 0,
                                                  'storageType': '',
                                                  'aliasId': ''
                                              }
                                          }
                                      },
                                      read: {
                                          'mqtt.0.shellies.shelly1-555EDB.relay.0': {
                                              convert: function (val) {
                                                  if (val == 'on') {
                                                      val = true;
                                                  } else {
                                                      val = false;
                                                  }
                                                  return val;
                                              },
                                              trigger: setTimeout(function(){
                                                          on({id:path + '.switch', change: 'ne'}, function (obj) {
                                                              if (getState(path + '.isTelegramInfoSwitch').val === true) {
                                                                  var value = obj.state.val;
                                                                  var name = getState(path + '.name').val;
                          
                                                                  _sendLogToTelegram(_findCorrectEmoji(name + ' wurde ' + (value === true ? 'eingeschaltet.' : 'ausgeschaltet.')));
                                                              } 
                                                          })
                                                      }, 500)
                                          },
                                      },
                                      write: {
                                          'mqtt.0.shellies.shelly1-555EDB.relay.0.command': {
                                              convert: function (val) {
                                                  if (val === true) {
                                                      val ='on';
                                                  } else {
                                                      val = 'off';
                                                  }
                                                  return val;
                                              },
                                          },
                                      }
                                  },
                                  'online': {
                                      common: {name: 'online', role: 'variable', type: 'boolean', desc: 'online', read: true, write: false, def: false,
                                          custom: {
                                              'influxdb.0': {
                                                  'enabled': true,
                                                  'changesOnly': true,
                                                  'debounce': 0,
                                                  'maxLength': 10,
                                                  'retention': 0,
                                                  'changesRelogInterval': 30,
                                                  'changesMinDelta': 0,
                                                  'storageType': '',
                                                  'aliasId': ''
                                              }
                                          }
                                      },
                                      read: {
                                          'mqtt.0.shellies.shelly1-555EDB.online': {
                                              trigger: setTimeout(function(){
                                                      on({id:path + '.online', change: 'ne'}, function (obj) {
                                                          var value = obj.state.val;
                          
                                                          if (value === false) {
                                                              setState('AllOwnCreated.0.shelly.isWrongState', true);
                                                          }
                          
                                                          if (getState(path + '.isTelegramInfo').val === true) {
                                                              var name = getState(path + '.name').val;
                          
                                                              _sendLogToTelegram(_findCorrectEmoji('OnlineStatus: ' + name + ' ist ' + (value === true ? 'wieder' : 'nicht') + ' erreichbar.'));
                                                          } 
                                                      })
                                                  }, 500)
                                          },
                                      },
                                      write: {}
                                  },
                                  'command': {
                                      common: {name: 'command', role: 'variable',  type: 'string', desc: 'command', read: true, write: true, def: ''},
                                      read: {
                                          'mqtt.0.shellies.shelly1-555EDB.command': {},
                                      },
                                      write: {
                                          'mqtt.0.shellies.shelly1-555EDB.command': {
                                          },
                                      }
                                  },
                                  'announce': {
                                      common: {name: 'announce', role: 'variable',  type: 'string', desc: 'announce', read: true, write: false, def: ''},
                                      read: {
                                          'mqtt.0.shellies.shelly1-555EDB.announce': {
                                              convert: function (val) {
                                                 var jsonValue = JSON.parse(val);
                                                 
                                                  calculateJson(jsonValue, 'Info');
                          
                                                  return val;
                                              },
                                          },
                                      },
                                  },
                                  'info': {
                                      common: {name: 'info', role: 'variable',  type: 'string', desc: 'info', read: true, write: false, def: ''},
                                      read: {
                                          'mqtt.0.shellies.shelly1-555EDB.info': {},
                                      },
                                  },      
                              }
                          }); 
                          
                          function calculateJson(jsonValue, subFolder) {
                              for (var key in jsonValue) {
                                  if (jsonValue.hasOwnProperty(key)) {
                                      try {  
                                          var jsonNewValue = JSON.parse(jsonValue[key]);  
                          
                                          calculateJson(jsonNewValue)
                                      } catch (e) {
                                          if (typeof jsonValue[key] == 'object') {
                                              for (var item in jsonValue[key]) {
                                                  //var commonType = getCommonType(item);
                                                  var commonType = null;
                                                  doCreateStates(path + '.' + subFolder +'.' + item, item, jsonValue[key][item], commonType) 
                                              }
                                          } else {
                                              doCreateStates(path + '.' + subFolder + '.' + key, key, jsonValue[key])    
                                          }    
                                      }
                                  }
                              }
                          }
                          
                          function doCreateStates(newObject, name, value, commonType) {
                              var obj = getObject(newObject);
                          
                              if (commonType == undefined) {
                                  commonType = {'name': name, 'role': 'state', 'type': 'string', desc: name, read: true, write: false, def: ''};
                              }
                          
                              if (commonType['type'] == 'number') {
                                  
                              } else {
                                  value = '' + value;
                              }
                          
                          	if (!obj) {
                          		setObject(newObject, {
                          			type: 'state',
                          			common: commonType,
                          			native: {}
                          		}, function(err, obj) {
                          			if (!err && obj) {
                          				console.log('Object for ' + obj.id + ' created');
                                          setState(newObject, value, true);
                          			}
                          		});
                          	} else {
                                  setState(newObject, value, true);    
                              }
                          
                              if (name == 'LWT') {
                                  setTimeout(function() {
                                      on({id:newObject, change: 'ne'}, function (obj) {
                                          if (getState(path + '.isTelegramInfo').val === true) {
                                              var value = obj.state.val;
                                              var name = getState(path + '.name').val;
                          
                                              _sendLogToTelegram(_findCorrectEmoji(name + ' wurde neu gestartet. Grund: ' + value));
                                          } 
                                      })
                                  }, 500)    
                              }
                          }
                          
                          
                          
                          
                          apollon77A Online
                          apollon77A Online
                          apollon77
                          wrote on last edited by
                          #427

                          @homecineplexx naja wenn duhier mit einem JavaScript sehr viele "States mirrorst" dann ist das ja alles "Ok" dasdie Zahl so hoch ist - was willst Du da noch optimieren 🙂 (Ausser es auf echte Aliases umzubauen, dann brauchst Du solche Skripte nicht) ...

                          Beitrag hat geholfen? Votet rechts unten im Beitrag :-) https://paypal.me/Apollon77 / https://github.com/sponsors/Apollon77

                          • Debug-Log für Instanz einschalten? Admin -> Instanzen -> Expertenmodus -> Instanz aufklappen - Loglevel ändern
                          • Logfiles auf Platte /opt/iobroker/log/… nutzen, Admin schneidet Zeilen ab
                          H 1 Reply Last reply
                          0
                          • apollon77A apollon77

                            @diginix Kannst Du denn Peak mit einem einfachen "neuen" Start reproduzieren?

                            DiginixD Offline
                            DiginixD Offline
                            Diginix
                            wrote on last edited by
                            #428

                            @apollon77 Vermute mal ja. Das Update war ja nur der Auslöser für den Neustart. Ich warte mal was @AlCalzone zu meinen Dateien sagt und dann kann ich das auch noch mal testen ohne Updates oder sonstige Änderungen.

                            ..:: So long! Tom ::..

                            NUC7i3 (Ubuntu Proxmox VM) | Echo Dots 2+3. Gen | Xiaomi Sensoren | Mi Robot 1S | Yeelight | Sonoff | Shelly | H801 RGB | Gosund SP1 | NodeMCU+ESP32 | Kostal Plenticore PV+BYD | openWB

                            apollon77A 1 Reply Last reply
                            0
                            • DiginixD Diginix

                              @apollon77 Vermute mal ja. Das Update war ja nur der Auslöser für den Neustart. Ich warte mal was @AlCalzone zu meinen Dateien sagt und dann kann ich das auch noch mal testen ohne Updates oder sonstige Änderungen.

                              apollon77A Online
                              apollon77A Online
                              apollon77
                              wrote on last edited by
                              #429

                              @diginix mach doch parallel ... also schick Ihm die files und mach mal stop und start und schau ob es wieder passiert ... Wäre denke auch für @AlCalzone ne interessante info

                              Beitrag hat geholfen? Votet rechts unten im Beitrag :-) https://paypal.me/Apollon77 / https://github.com/sponsors/Apollon77

                              • Debug-Log für Instanz einschalten? Admin -> Instanzen -> Expertenmodus -> Instanz aufklappen - Loglevel ändern
                              • Logfiles auf Platte /opt/iobroker/log/… nutzen, Admin schneidet Zeilen ab
                              DiginixD 1 Reply Last reply
                              0
                              • apollon77A apollon77

                                @homecineplexx naja wenn duhier mit einem JavaScript sehr viele "States mirrorst" dann ist das ja alles "Ok" dasdie Zahl so hoch ist - was willst Du da noch optimieren 🙂 (Ausser es auf echte Aliases umzubauen, dann brauchst Du solche Skripte nicht) ...

                                H Offline
                                H Offline
                                homecineplexx
                                wrote on last edited by
                                #430

                                @apollon77 said in js-controller 4.0 jetzt im BETA/LATEST!:

                                Ausser es auf echte Aliases umzubauen, dann brauchst Du solche Skripte nicht

                                geb ich dir absolut recht, allerdings lass ich dort auch zusätzlich gleich gewisse Datenpunkte in die Influxdb schreiben und zusätzlich überwachen. ich weiß nicht ob ich das mit Alias kann?

                                apollon77A 1 Reply Last reply
                                0
                                • H homecineplexx

                                  @apollon77 said in js-controller 4.0 jetzt im BETA/LATEST!:

                                  Ausser es auf echte Aliases umzubauen, dann brauchst Du solche Skripte nicht

                                  geb ich dir absolut recht, allerdings lass ich dort auch zusätzlich gleich gewisse Datenpunkte in die Influxdb schreiben und zusätzlich überwachen. ich weiß nicht ob ich das mit Alias kann?

                                  apollon77A Online
                                  apollon77A Online
                                  apollon77
                                  wrote on last edited by
                                  #431

                                  @homecineplexx Auch wenn ziemlich Off-Topic hier: Für Aliase kannst du auch Influxdb logging aktivieren und für "überwachen" wirst Du ggf eigene Skripte brauchen. Lange Rede ... Wenn die Skripte das tun was Du sagst und da "so viel Changes" zusammenkommen wie Du oben geschrieben hast ist doch erstmal alles ok ... Wichtig ist zu unterscheiden ob so soll oder da ein Skript Amok läuft

                                  Beitrag hat geholfen? Votet rechts unten im Beitrag :-) https://paypal.me/Apollon77 / https://github.com/sponsors/Apollon77

                                  • Debug-Log für Instanz einschalten? Admin -> Instanzen -> Expertenmodus -> Instanz aufklappen - Loglevel ändern
                                  • Logfiles auf Platte /opt/iobroker/log/… nutzen, Admin schneidet Zeilen ab
                                  1 Reply Last reply
                                  0
                                  • apollon77A apollon77

                                    @diginix mach doch parallel ... also schick Ihm die files und mach mal stop und start und schau ob es wieder passiert ... Wäre denke auch für @AlCalzone ne interessante info

                                    DiginixD Offline
                                    DiginixD Offline
                                    Diginix
                                    wrote on last edited by
                                    #432

                                    @apollon77 Hm, ein iob stop mit anschließendem Reboot des Servers, also komplette Proxmox Host (gab Kernel Updates) und somit ja dann im Anschluss auch wieder ein iob start hat keinerlei Peak erzeugt. Nun wird nat. der RAM vom js-c über history erfasst und der Adapter muss natürlich erstmal laufen. Was ja aber gestern auch funktionierte.

                                    Daher habe ich direkt noch mal ein iob stop, ps auxww | grep "io.", iob status, iob start gemacht.
                                    "Leider" auch ohne Auffälligkeiten.

                                    f1f8efc6-9e2d-41d9-9061-a1f4883343f8-image.png

                                    Aber ich vermute, dass genau der Controller Peak von gestern auch in der Vergangenheit seit 4.x für die OOM Kills bei mir ursächlich war. Was den Peak selbst auslöst, ist leider weiterhin unbekannt.
                                    Wird nach einem js-controller Update noch etwas gemacht was bei einem Neustart der selben Controller Version dann nicht mehr geschieht?

                                    ..:: So long! Tom ::..

                                    NUC7i3 (Ubuntu Proxmox VM) | Echo Dots 2+3. Gen | Xiaomi Sensoren | Mi Robot 1S | Yeelight | Sonoff | Shelly | H801 RGB | Gosund SP1 | NodeMCU+ESP32 | Kostal Plenticore PV+BYD | openWB

                                    AlCalzoneA 1 Reply Last reply
                                    0
                                    • DiginixD Diginix

                                      @apollon77 Hm, ein iob stop mit anschließendem Reboot des Servers, also komplette Proxmox Host (gab Kernel Updates) und somit ja dann im Anschluss auch wieder ein iob start hat keinerlei Peak erzeugt. Nun wird nat. der RAM vom js-c über history erfasst und der Adapter muss natürlich erstmal laufen. Was ja aber gestern auch funktionierte.

                                      Daher habe ich direkt noch mal ein iob stop, ps auxww | grep "io.", iob status, iob start gemacht.
                                      "Leider" auch ohne Auffälligkeiten.

                                      f1f8efc6-9e2d-41d9-9061-a1f4883343f8-image.png

                                      Aber ich vermute, dass genau der Controller Peak von gestern auch in der Vergangenheit seit 4.x für die OOM Kills bei mir ursächlich war. Was den Peak selbst auslöst, ist leider weiterhin unbekannt.
                                      Wird nach einem js-controller Update noch etwas gemacht was bei einem Neustart der selben Controller Version dann nicht mehr geschieht?

                                      AlCalzoneA Offline
                                      AlCalzoneA Offline
                                      AlCalzone
                                      Developer
                                      wrote on last edited by
                                      #433

                                      @diginix sagte in js-controller 4.0 jetzt im BETA/LATEST!:

                                      Wird nach einem js-controller Update noch etwas gemacht was bei einem Neustart der selben Controller Version dann nicht mehr geschieht?

                                      iobroker setup first vielleicht @apollon77 ?

                                      Warum `sudo` böse ist: https://forum.iobroker.net/post/17109

                                      foxriver76F apollon77A 2 Replies Last reply
                                      0
                                      • AlCalzoneA AlCalzone

                                        @diginix sagte in js-controller 4.0 jetzt im BETA/LATEST!:

                                        Wird nach einem js-controller Update noch etwas gemacht was bei einem Neustart der selben Controller Version dann nicht mehr geschieht?

                                        iobroker setup first vielleicht @apollon77 ?

                                        foxriver76F Offline
                                        foxriver76F Offline
                                        foxriver76
                                        Developer
                                        wrote on last edited by
                                        #434

                                        @alcalzone Ja, wird ausgeführt und darin werden paar Objekte aufgeräumt, sichergestellt, dass systemSecret, certs da sind + Sets Migration.

                                        Habe jetzt nicht viel gelesen, aber Sets Migration sind approx. n calls gegen die DB, wobei n die Anzahl an Objekten ist.

                                        Videotutorials & mehr

                                        Hier könnt ihr mich unterstützen.

                                        1 Reply Last reply
                                        0
                                        • AlCalzoneA Offline
                                          AlCalzoneA Offline
                                          AlCalzone
                                          Developer
                                          wrote on last edited by
                                          #435

                                          Hmm also mit den Dateien, die ich von @Diginix bekommen hab, startet der Controller-Prozess problemlos und dümpelt dann bei so 300 MB RAM. Ich probier jetzt mal nur setup first zu debuggen.

                                          Warum `sudo` böse ist: https://forum.iobroker.net/post/17109

                                          1 Reply Last reply
                                          0
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate
                                          FAQ Cloud / IOT
                                          HowTo: Node.js-Update
                                          HowTo: Backup/Restore
                                          Downloads
                                          BLOG

                                          363

                                          Online

                                          32.4k

                                          Users

                                          81.3k

                                          Topics

                                          1.3m

                                          Posts
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Login

                                          • Don't have an account? Register

                                          • Login or register to search.
                                          • First post
                                            Last post
                                          0
                                          • Recent
                                          • Tags
                                          • Unread 0
                                          • Categories
                                          • Unreplied
                                          • Popular
                                          • GitHub
                                          • Docu
                                          • Hilfe