NEWS
Adapter/Instanz neu starten lassen, wenn Status Gelb/Rot
-
@TH-G sagte in Adapter/Instanz neu starten lassen, wenn Status Gelb/Rot:
ReferenceError: objPl ist nicht definiert
Ersetze im Skript
objPl
durchinstanceObj
-
Geht leider auch nicht:
host.raspberrypi 2020-05-29 16:55:16.321 info instance system.adapter.luftdaten.0 terminated with code 0 (NO_ERROR)
luftdaten.0 2020-05-29 16:55:15.800 info (474) Terminated (NO_ERROR): Without reason
luftdaten.0 2020-05-29 16:55:05.753 info (474) starting. Version 0.0.15 in /opt/iobroker/node_modules/iobroker.luftdaten, node: v12.17.0, js-controller: 3.1.4
host.raspberrypi 2020-05-29 16:55:05.314 info Do not restart adapter system.adapter.modbus.1 because disabled or deleted
host.raspberrypi 2020-05-29 16:55:05.313 error instance system.adapter.modbus.1 terminated with code 3 (NO_ADAPTER_CONFIG_FOUND)
host.raspberrypi 2020-05-29 16:55:04.928 info instance system.adapter.dwd.0 terminated with code 0 (NO_ERROR)
modbus.1 2020-05-29 16:55:04.797 warn (453) Terminated (NO_ADAPTER_CONFIG_FOUND): Without reason
modbus.1 2020-05-29 16:55:04.781 error (453) adapter disabled
dwd.0 2020-05-29 16:55:04.400 info (422) Terminated (NO_ERROR): Without reason
host.raspberrypi 2020-05-29 16:55:04.265 info instance system.adapter.luftdaten.0 started with pid 474
dwd.0 2020-05-29 16:55:02.065 info (422) starting. Version 2.4.9 in /opt/iobroker/node_modules/iobroker.dwd, node: v12.17.0, js-controller: 3.1.4
host.raspberrypi 2020-05-29 16:55:01.872 info instance system.adapter.modbus.1 terminated with code 156 (START_IMMEDIATELY_AFTER_STOP)
modbus.1 2020-05-29 16:55:01.559 info (403) Connected to slave 192.168.178.82
host.raspberrypi 2020-05-29 16:55:01.358 info "system.adapter.modbus.1" disabled
host.raspberrypi 2020-05-29 16:55:01.319 info stopInstance system.adapter.modbus.1 killing pid 403
modbus.1 2020-05-29 16:55:01.344 info (403) Terminated (START_IMMEDIATELY_AFTER_STOP): Without reason
modbus.1 2020-05-29 16:55:00.852 info (403) starting. Version 3.0.0 in /opt/iobroker/node_modules/iobroker.modbus, node: v12.17.0, js-controller: 3.1.4
modbus.1 2020-05-29 16:55:00.324 info (403) Got terminate signal TERMINATE_YOURSELF
host.raspberrypi 2020-05-29 16:55:00.318 info stopInstance system.adapter.modbus.1 send kill signal
host.raspberrypi 2020-05-29 16:55:00.316 info stopInstance system.adapter.modbus.1 (force=false, process=true)
javascript.0 2020-05-29 16:55:00.300 info (29318) script.js.common.Neustart_nach_Fehler_Modbus: modbus Neustart
host.raspberrypi 2020-05-29 16:55:00.028 info instance system.adapter.dwd.0 started with pid 422
host.raspberrypi 2020-05-29 16:54:59.074 info instance system.adapter.modbus.1 started with pid 403
host.raspberrypi 2020-05-29 16:54:59.015 info "system.adapter.modbus.1" enabled
javascript.0 2020-05-29 16:54:58.983 info (29318) script.js.common.Neustart_nach_Fehler_Modbus: modbus Neustart
host.raspberrypi 2020-05-29 16:54:01.936 info Do not restart adapter system.adapter.modbus.1 because disabled or deleted
host.raspberrypi 2020-05-29 16:54:01.934 error instance system.adapter.modbus.1 terminated with code 3 (NO_ADAPTER_CONFIG_FOUND)
modbus.1 2020-05-29 16:54:01.397 warn (32717) Terminated (NO_ADAPTER_CONFIG_FOUND): Without reason
modbus.1 2020-05-29 16:54:01.385 error (32717) adapter disabled
host.raspberrypi 2020-05-29 16:54:00.817 info instance system.adapter.modbus.1 terminated with code 11 (ADAPTER_REQUESTED_TERMINATION)
modbus.1 2020-05-29 16:54:00.345 info (32695) Got terminate signal TERMINATE_YOURSELF
host.raspberrypi 2020-05-29 16:54:00.340 info stopInstance system.adapter.modbus.1 send kill signal
host.raspberrypi 2020-05-29 16:54:00.337 info stopInstance system.adapter.modbus.1 (force=false, process=true)
modbus.1 2020-05-29 16:54:00.297 warn (32695) Got terminate signal. Checking desired PID: 32717 vs own PID 32695
modbus.1 2020-05-29 16:54:00.283 info (32695) Terminated (ADAPTER_REQUESTED_TERMINATION): Without reason
modbus.1 2020-05-29 16:54:00.281 info (32695) terminating
modbus.1 2020-05-29 16:54:00.275 warn (32695) Got terminate signal. Checking desired PID: 0 vs own PID 32695
host.raspberrypi 2020-05-29 16:53:58.995 info "system.adapter.modbus.1" disabled
modbus.1 2020-05-29 16:53:58.975 info (32695) Connected to slave 192.168.178.82
modbus.1 2020-05-29 16:53:58.477 info (32695) starting. Version 3.0.0 in /opt/iobroker/node_modules/iobroker.modbus, node: v12.17.0, js-controller: 3.1.4 -
Wieder Fehler und das Skript geht nicht
Habt ihr beiden keine Idee mehr? Morgen geht es endlich ein paar Tage in den Kurzurlaub und so kann ich das nicht lassen.
Es frustet mich sehr.
-
@TH-G sagte in Adapter/Instanz neu starten lassen, wenn Status Gelb/Rot:
javascript.0 2020-05-29 16:54:58.983 info (29318) script.js.common.Neustart_nach_Fehler_Modbus: modbus Neustart
host.raspberrypi 2020-05-29 16:54:01.936 info Do not restart adapter system.adapter.modbus.1 because disabled or deleteddas verstehe ich nicht.. der macht den neustart aber die instanz soll nicht da sein ??
@AlCalzone ist da was besonders mit dem modbus ?? oder haben wir ein Problem mit 2 instanzen.. -
Zur Info.
Ich habe gestern noch den RPI4 vom LAN getrennt und habe diesen per WLAN verbunden und auch damit das gleiche Problem mit dem Modbus.
Es kann also nach meiner Einschätzung nicht mehr an der Netzwerkschnittstelle liegen. Wenn das Problem nicht der Modbusadapter selbst ist oder ein anderes Softwareproblem, können eigentlich nur noch beide Wechselrichter defekt sein aber das wär schon sehr merkwürdig.
Habe nun auch ein Linuxupdate auf den allerneusten Stand durchgeführt ioBrocker ist bereits aktuell.
Ich bin nun leider drei Tage nicht da und kann erst am Montag wieder antworten und dann werde ich auch sehen was passiert ist und meine Frau soll einfach das Gerät alle paar Stunden aus und einschalten.
Danke für eure Hilfe und hoffentlich finden wir eine Lösung mit dem Skript, denn damit könnte ich leben.
-
-
@AlCalzone ne eigentlich nicht, da der nur bei einem Statuswechsel triggert .
also von true auf false.. aber nicht von false auf false
-
Hallo,
wieder da und ich konnte von unterwegs die Änderung durchführen aber hat leider nichts gebracht.
Es ändert sich aber folgendes. Aus dem Grünen Punkt wird nun ein grauer und die Instanz steht auf Deaktiviert. Jetzt musste die Instanz nur noch neu gestartet werden.
Hier nun der Log:
host.raspberrypi 2020-06-02 00:06:33.268 info instance system.adapter.modbus.1 terminated with code 11 (ADAPTER_REQUESTED_TERMINATION)
modbus.1 2020-06-02 00:06:32.775 info (6700) Got terminate signal TERMINATE_YOURSELF
host.raspberrypi 2020-06-02 00:06:32.773 info stopInstance system.adapter.modbus.1 send kill signal
host.raspberrypi 2020-06-02 00:06:32.772 info stopInstance system.adapter.modbus.1 (force=false, process=true)
modbus.1 2020-06-02 00:06:32.750 info (6700) Terminated (ADAPTER_REQUESTED_TERMINATION): Without reason
modbus.1 2020-06-02 00:06:32.748 info (6700) terminating
modbus.1 2020-06-02 00:06:32.746 info (6700) Got terminate signal TERMINATE_YOURSELF
host.raspberrypi 2020-06-02 00:06:32.738 info stopInstance system.adapter.modbus.1 send kill signal
host.raspberrypi 2020-06-02 00:06:32.736 info stopInstance system.adapter.modbus.1 (force=false, process=true)
host.raspberrypi 2020-06-02 00:06:32.735 info "system.adapter.modbus.1" disabled
modbus.1 2020-06-02 00:06:32.721 info (6700) Connected to slave 192.168.178.82
modbus.1 2020-06-02 00:06:32.229 info (6700) starting. Version 3.0.0 in /opt/iobroker/node_modules/iobroker.modbus, node: v12.17.0, js-controller: 3.1.4
host.raspberrypi 2020-06-02 00:06:31.103 info instance system.adapter.modbus.1 started with pid 6700
host.raspberrypi 2020-06-02 00:06:31.063 info "system.adapter.modbus.1" enabled
javascript.0 2020-06-02 00:06:31.036 info (1665) script.js.common.Neustart_nach_Fehler_Modbus: modbus Neustart
host.raspberrypi 2020-06-02 00:05:31.591 info instance system.adapter.modbus.1 terminated with code 11 (ADAPTER_REQUESTED_TERMINATION)
modbus.1 2020-06-02 00:05:31.067 info (18891) Terminated (ADAPTER_REQUESTED_TERMINATION): Without reason
modbus.1 2020-06-02 00:05:31.066 info (18891) terminating
modbus.1 2020-06-02 00:05:31.064 info (18891) Got terminate signal TERMINATE_YOURSELF
host.raspberrypi 2020-06-02 00:05:31.060 info stopInstance system.adapter.modbus.1 send kill signal
host.raspberrypi 2020-06-02 00:05:31.057 info stopInstance system.adapter.modbus.1 (force=false, process=true)
host.raspberrypi 2020-06-02 00:05:31.055 info "system.adapter.modbus.1" disabled
modbus.1 2020-06-02 00:05:31.021 info (18891) Disconnected from slave 192.168.178.82
modbus.1 2020-06-02 00:05:31.020 error (18891) Cannot write [40236]: {"errorCode":144,"exceptionCode":3,"message":"ILLEGAL DATA VALUE"}
modbus.1 2020-06-02 00:05:30.636 info (18891) Connected to slave 192.168.178.82
host.raspberrypi 2020-06-02 00:05:12.149 info instance system.adapter.luftdaten.0 terminated with code 0 (NO_ERROR)
luftdaten.0 2020-06-02 00:05:11.624 info (6487) Terminated (NO_ERROR): Without reason
host.raspberrypi 2020-06-02 00:05:07.367 info instance system.adapter.dwd.0 terminated with code 0 (NO_ERROR)
dwd.0 2020-06-02 00:05:06.835 info (6509) Terminated (NO_ERROR): Without reason
dwd.0 2020-06-02 00:05:05.909 info (6509) starting. Version 2.4.9 in /opt/iobroker/node_modules/iobroker.dwd, node: v12.17.0, js-controller: 3.1.4
host.raspberrypi 2020-06-02 00:05:04.092 info instance system.adapter.dwd.0 started with pid 6509
luftdaten.0 2020-06-02 00:05:01.545 info (6487) starting. Version 0.0.15 in /opt/iobroker/node_modules/iobroker.luftdaten, node: v12.17.0, js-controller: 3.1.4
host.raspberrypi 2020-06-02 00:05:00.061 info instance system.adapter.luftdaten.0 started with pid 6487
javascript.0 2020-06-02 00:04:50.908 info (1665) script.js.common.Neustart_nach_Fehler_Modbus: registered 1 subscription and 0 schedules
javascript.0 2020-06-02 00:04:50.850 info (1665) Start javascript script.js.common.Neustart_nach_Fehler_Modbus
modbus.1 2020-06-02 00:04:30.643 warn (18891) On error: {"code":"ERR_STREAM_WRITE_AFTER_END"}
modbus.1 2020-06-02 00:04:30.642 error (18891) Client in error state.
modbus.1 2020-06-02 00:04:30.641 error (18891) Socket Error -
@TH-G Ok jetzt noch eine Kleinigkeit. Der Adapter setzt info.connection beim Start auf false. Diese Änderung müssen wir ignorieren. Ich bin nicht sicher ob das oben die letzte, aktuelle Version war. Aber so in etwa müsste es dann aussehen:
let ignore = false; on({ id: "modbus.1.info.connection", change: "ne", val: false }, () => { if (ignore) { // Nur 1x ignorieren, damit wir den nächsten Hänger mitbekommen ignore = false; return; } const instanceObj = getObject("system.adapter.modbus.1"); instanceObj.common.enabled = false; // Adapter anschalten sicher ist das log("modbus deaktiviert"); setObject("system.adapter.modbus.1", instanceObj, function (err) { if (err) log("Cannot write object: " + err); }); // warte ne minute dann mach wieder an setTimeout(function () { log("modbus wieder aktiviert"); // Nächsten Trigger ignorieren ignore = true; instanceObj.common.enabled = true; // Adapter anschalten setObject("system.adapter.modbus.1", instanceObj, function (err) { if (err) log("Cannot write object: " + err); }); // Zur Sicherheit nach 15 Sekunden nicht mehr ignorieren setTimeout(() => { ignore = false; }, 15000); }, 60000); });
-
Fehler ist wieder aufgetreten und das Skript hat nun perfekt funktioniert
DANKE
modbus.1 2020-06-02 14:52:38.964 info (23726) Connected to slave 192.168.178.82
modbus.1 2020-06-02 14:52:38.480 info (23726) starting. Version 3.0.0 in /opt/iobroker/node_modules/iobroker.modbus, node: v12.17.0, js-controller: 3.1.4
modbus.1 2020-06-02 14:51:37.356 info (18246) Terminated (ADAPTER_REQUESTED_TERMINATION): Without reason
modbus.1 2020-06-02 14:51:37.354 info (18246) terminating
modbus.1 2020-06-02 14:51:37.347 info (18246) Got terminate signal TERMINATE_YOURSELF
modbus.1 2020-06-02 14:51:37.282 warn (18246) Poll error count: 1 code: {"err":"timeout"}
modbus.1 2020-06-02 14:51:37.280 error (18246) Client in error state.
modbus.1 2020-06-02 14:51:37.279 error (18246) Request timed out.
modbus.1 2020-06-02 14:51:37.277 warn (18246) Error: undefinedjavascript.0 2020-06-02 14:52:37.306 info (1665) script.js.common.Neustart_nach_Fehler_Modbus: modbus wieder aktiviert
javascript.0 2020-06-02 14:51:37.300 info (1665) script.js.common.Neustart_nach_Fehler_Modbus: modbus deaktivierthost.raspberrypi 2020-06-02 14:52:37.340 info "system.adapter.modbus.1" enabled
host.raspberrypi 2020-06-02 14:51:37.885 info instance system.adapter.modbus.1 terminated with code 11 (ADAPTER_REQUESTED_TERMINATION)
host.raspberrypi 2020-06-02 14:51:37.340 info stopInstance system.adapter.modbus.1 send kill signal
host.raspberrypi 2020-06-02 14:51:37.336 info stopInstance system.adapter.modbus.1 (force=false, process=true)
host.raspberrypi 2020-06-02 14:51:37.332 info "system.adapter.modbus.1" disabled -
@TH-G Wenn das alles so schnell geht, kannst du ggf. auch die Timeouts runtersetzen, z.B. 60000 -> 10000 und 15000 -> 5000 (oder 3000)
-
Kurze Rückinfo.
Läuft alles stabil mit deinem Skript. Es gibt nur einen Schönheitsfehler. Wenn ioBrocker oder der RPI neu gestartet werden, verhindert das Skript, dass der Modbus Adapter gestartet wird. Ich muss dann erst das Skript abschalten, dann kann der Adapter gestartet werden und erst danach wieder das Skript.
Das ist leider nicht so schön.
Nach dem Update auf die aktuelle JS Version habe ich wieder sehr oft Ausfälle vom Adapter. Diesen Eindruck hatte ich schon länger, dass nicht (nur) mögliche Netzwerkprobleme dieses Problem verursachen sondern auch iobroker damit zu tun hat.
-
@TH-G Versuche mal folgendes:
In obigem Skript zwischen Zeile 1 und 3 folgendes einfügen:// Beim Start des Adapters nicht reagieren, wenn dieser nach dem Skript gestartet wird. if (!getState("system.adapter.modbus.1.alive").val) { ignore = true; }