NEWS
[gelöst] MQTT Server Restart?
-
Schade…
So ganz gelöst ist mein Problem trotzdem nicht.
Heute hatte ich wieder einen Ausfall.
Das hier stand in der Log-Datei:
socketio.0 2017-12-10 14:06:36.187 info 2017-12-10T13:06:36.187Z Connected system.user.admin mqtt.0 2017-12-10 14:06:36.099 info Client [ZombosHTML] closed mqtt.0 2017-12-10 14:06:21.251 info Client [ZombosHTML] subscribes on "mqtt.0.lab.*" with regex /^mqtt\.0\.lab\..*/ mqtt.0 2017-12-10 14:06:21.251 info Client [ZombosHTML] subscribes on "mqtt.0.lab.*" with regex /^lab\..*/ mqtt.0 2017-12-10 14:06:21.159 info Client [ZombosHTML] connected socketio.0 2017-12-10 14:06:21.117 info 2017-12-10T13:06:21.117Z Connected system.user.admin mqtt.0 2017-12-10 14:06:20.991 info Client [undefined] closed mqtt.0 2017-12-10 14:06:20.989 info Client [undefined] closed mqtt.0 2017-12-10 14:06:20.965 info Client [undefined] closed mqtt.0 2017-12-10 14:06:20.964 info Client [undefined] closed mqtt.0 2017-12-10 14:06:20.963 info Client [undefined] closed mqtt.0 2017-12-10 14:06:20.963 info Client [undefined] closed mqtt.0 2017-12-10 14:06:20.963 info Client [undefined] closed mqtt.0 2017-12-10 14:06:20.962 info Client [undefined] closed mqtt.0 2017-12-10 14:06:20.960 info Client [undefined] closed mqtt.0 2017-12-10 14:06:20.959 info Client [undefined] closed mqtt.0 2017-12-10 14:06:20.957 info Client [undefined] closed mqtt.0 2017-12-10 14:06:20.956 info Client [undefined] closed mqtt.0 2017-12-10 14:06:20.953 info Client [undefined] closed mqtt.0 2017-12-10 14:06:20.951 info Client [undefined] closed mqtt.0 2017-12-10 14:06:20.950 info Client [undefined] closed mqtt.0 2017-12-10 14:06:20.950 info Client [undefined] closed mqtt.0 2017-12-10 14:06:20.949 info Client [undefined] closed mqtt.0 2017-12-10 14:06:20.948 info Client [undefined] closed mqtt.0 2017-12-10 14:06:20.927 info Client [ZombosHTML] closed mqtt.0 2017-12-10 14:06:20.925 info Client [undefined] closed mqtt.0 2017-12-10 14:06:20.924 info Client [undefined] closed mqtt.0 2017-12-10 14:06:20.924 info Client [undefined] closed mqtt.0 2017-12-10 14:06:20.923 info Client [undefined] closed mqtt.0 2017-12-10 14:06:20.923 info Client [undefined] closed mqtt.0 2017-12-10 14:06:20.922 info Client [undefined] closed mqtt.0 2017-12-10 14:06:20.905 info Client [undefined] closed mqtt.0 2017-12-10 14:06:20.898 info Client [undefined] closed mqtt.0 2017-12-10 14:06:20.898 info Client [undefined] closed mqtt.0 2017-12-10 14:06:20.897 info Client [undefined] closed mqtt.0 2017-12-10 14:06:20.895 info Client [undefined] closed mqtt.0 2017-12-10 14:06:20.895 info Client [undefined] closed mqtt.0 2017-12-10 14:06:20.892 info Client [undefined] closed mqtt.0 2017-12-10 14:06:20.892 info Client [undefined] closed mqtt.0 2017-12-10 14:06:20.891 info Client [undefined] closed mqtt.0 2017-12-10 14:06:20.890 info Client [undefined] closed mqtt.0 2017-12-10 14:06:20.890 info Client [undefined] closed mqtt.0 2017-12-10 14:06:20.889 info Client [undefined] closed mqtt.0 2017-12-10 14:06:20.886 info Client [undefined] closed mqtt.0 2017-12-10 14:06:20.884 info Client [undefined] closed mqtt.0 2017-12-10 14:06:20.882 info Client [undefined] closed mqtt.0 2017-12-10 14:06:01.621 info Client [Countdown_Lab] subscribes on "mqtt.0.lab.*" with regex /^mqtt\.0\.lab\..*/ mqtt.0 2017-12-10 14:06:01.620 info Client [Countdown_Lab] subscribes on "mqtt.0.lab.*" with regex /^lab\..*/ mqtt.0 2017-12-10 14:06:01.613 info Client [Countdown_Lab] connected mqtt.0 2017-12-10 14:05:18.029 info Client [ZombosHTML] subscribes on "lab.*" with regex /^mqtt\.0\.lab\..*/ mqtt.0 2017-12-10 14:05:18.029 info Client [ZombosHTML] subscribes on "lab.*" with regex /^lab\..*/ mqtt.0 2017-12-10 14:05:18.014 info Client [ZombosHTML] connected mqtt.0 2017-12-10 14:05:13.758 info Client [labspinnen8266] subscribes on "mqtt.0.lab.labspinnen8266" mqtt.0 2017-12-10 14:05:13.743 info Client [labspinnen8266] connected mqtt.0 2017-12-10 14:05:08.360 info Client [labrobot8266] subscribes on "mqtt.0.lab.labrobot8266" mqtt.0 2017-12-10 14:05:08.338 info Client [labrobot8266] connected mqtt.0 2017-12-10 14:05:07.683 info Starting MQTT-WebSocket server on port 1884 mqtt.0 2017-12-10 14:05:07.681 info Starting MQTT server on port 1883 mqtt.0 2017-12-10 14:05:07.365 info starting. Version 1.2.5 in C:/ioBroker/node_modules/iobroker.mqtt, node: v6.10.3 host.TARDIS 2017-12-10 14:05:06.323 info instance system.adapter.mqtt.0 started with pid 8360 host.TARDIS 2017-12-10 14:05:06.319 info object change system.adapter.mqtt.0 host.TARDIS 2017-12-10 14:05:06.309 info instance system.adapter.mqtt.0 terminated with code null () host.TARDIS 2017-12-10 14:05:06.309 warn instance system.adapter.mqtt.0 terminated due to SIGTERM javascript.0 2017-12-10 14:05:06.306 info script.js.Skript_MQTT+SOCKETIO_RESTART: setObject(id=system.adapter.mqtt.0, obj={"_id":"system.adapter.mqtt.0","type":"instance","common":{"name":"mqtt","require":{"js-controller":">=0.10.0"},"versio javascript.0 2017-12-10 14:05:06.306 info script.js.Skript_MQTT+SOCKETIO_RESTART: getObject(id=system.adapter.mqtt.0, enumName=undefined) => {"_id":"system.adapter.mqtt.0","type":"instance","common":{"name":"mqtt","require":{"js-controller": javascript.0 2017-12-10 14:05:06.305 info script.js.Skript_MQTT+SOCKETIO_RESTART: ########## MQTT SCRIPT-RESTART ######### host.TARDIS 2017-12-10 14:05:06.239 info stopInstance system.adapter.mqtt.0 killing pid 784 host.TARDIS 2017-12-10 14:05:06.239 info stopInstance system.adapter.mqtt.0 host.TARDIS 2017-12-10 14:05:06.239 info object change system.adapter.mqtt.0 mqtt.0 2017-12-10 14:05:06.148 info starting. Version 1.2.5 in C:/ioBroker/node_modules/iobroker.mqtt, node: v6.10.3 host.TARDIS 2017-12-10 14:05:05.306 info instance system.adapter.mqtt.0 started with pid 784 host.TARDIS 2017-12-10 14:05:05.300 info "system.adapter.mqtt.0" enabled host.TARDIS 2017-12-10 14:05:05.300 info object change system.adapter.mqtt.0 javascript.0 2017-12-10 14:05:05.290 info script.js.Skript_MQTT+SOCKETIO_RESTART: setObject(id=system.adapter.mqtt.0, obj={"_id":"system.adapter.mqtt.0","type":"instance","common":{"name":"mqtt","require":{"js-controller":">=0.10.0"},"versio javascript.0 2017-12-10 14:05:05.290 info script.js.Skript_MQTT+SOCKETIO_RESTART: getObject(id=system.adapter.mqtt.0, enumName=undefined) => {"_id":"system.adapter.mqtt.0","type":"instance","common":{"name":"mqtt","require":{"js-controller": host.TARDIS 2017-12-10 14:05:05.291 info instance system.adapter.mqtt.0 terminated with code null () host.TARDIS 2017-12-10 14:05:05.291 warn instance system.adapter.mqtt.0 terminated due to SIGTERM javascript.0 2017-12-10 14:05:05.290 info script.js.Skript_MQTT+SOCKETIO_RESTART: ########## MQTT SCRIPT-RESTART #########
Die unterste Zeile gibt an, dass das Skript gefeuert und einen Restart initiiert hat.
Warum MQTT plötzlich aus, war ließ sich dem Log leider immer noch nicht entnehmen.
Ich habe jetzt aber die 10 Sekunden Verzögerung eingebaut (die war noch nicht drin).
Vielleicht ging es MQTT einfach zu schnell und der Adapter hat sich "verschluckt" oder so.
WÜnschte, ich könnte den Fehler finden, der das alles auslöst oder ihn zumindest reproduzieren.
-
Mir fällt noch ein dass wir den Adapter eventuell erst aus und dann wieder einschalten sollten.
Moment wird der Wert ja nur auf true gesetzt was er bereits ist dadurch kein Neustart sondern nur Einschalten
–-----------------------
Send from mobile device
-
guter Hinweis.
Werde ich einbauen:
5 Sek Warten: Ausschalten.
5 Sek Warten: Einschalten.
Vielen Dank!
Was mich wundert: Ist sowas nicht eigentlich sowieso schon im MQTT-Adapter eingebaut?
-
Sollte eigentlich
–-----------------------
Send from mobile device
-
Tja… Um so seltsamer.
Werde den Verdacht nicht los, dass entweder ich irgendwo einen üblen Fehler eingebaut habe.
Oder dass eben doch noch irgendwo ein Bug steckt.
MQTT sollte doch eigentlich sehr ausfallsicher sein.
Würde mich auch interessieren, ob es auf einem RasPi mit iobroker zum sleben Fehler kommt.
Kann halt nicht testen, weil ich den Fehler bisher nicht selbst hervorrufen kann.
Wie auch immer:
Ich habe jetzt diesen Code eingebaut. Mal sehen, wie es die nächsten Stunden bzw. Tage damit klappt.
on({id: "system.adapter.mqtt.0.alive"/*mqtt.0.alive*/, val: false}, function (obj) { // Adapter erstmal ausschalten, um ganz sicher zug ehen. console.log('########## MQTT SCRIPT-SAFETY-SHUTDOWN #########'); var obj3 = getObject("system.adapter.mqtt.0"); obj3.common.enabled = false; setObject("system.adapter.mqtt.0", obj3); //Timeout, erst 5 sekunden nach status alive = false neustart initieren timeout = setTimeout(function () { var obj2 = getObject("system.adapter.mqtt.0").common.enabled; //Nur ausfuehren wen adapter enabled ist UND der alive status immernoch false if (obj2 === true && getState("system.adapter.mqtt.0.alive").val === false) { console.log('########## MQTT SCRIPT-RESTART #########'); var obj = getObject("system.adapter.mqtt.0"); obj.common.enabled = true; setObject("system.adapter.mqtt.0", obj); } // Hier stehen die 5 sekunden }, 5000); });
-
Das Script wird so nicht gehen entweder das ausschalten ist innerhalb der if oder du musst diese ändern.
Die überprüft nämlich ob der Adapter enabled ist
–-----------------------
Send from mobile device
-
ok, danke fürs draufschauen.
Weiß nicht so genau, wo der unterschied zwischen "enabled", "live" und "connected" ist.
Ich dachte, enabled ist der Play/Pause-Button bei den Instanzen.
"live" ob der Adapter nun läuft oder nicht.
Und dann ist da noch "connected"(to host?)
Ich bau es in die if-Schleife ein.
-
Richtig, connected ob er Verbindung hat.
Ich hatte bewust die Prüfung auf enabled eingebaut da du den Adapter sonst nie ausschalten kannst ohne dass Script zu stoppen
–-----------------------
Send from mobile device
-
on({id: "system.adapter.mqtt.0.alive"/*mqtt.0.alive*/, val: false}, function (obj) { //Timeout, erst 5 sekunden nach status alive = false neustart initieren timeout = setTimeout(function () { var obj2 = getObject("system.adapter.mqtt.0").common.enabled; //Nur ausfuehren wenn Adapter enabled ist UND der alive status immernoch false if (obj2 === true && getState("system.adapter.mqtt.0.alive").val === false) { // Adapter erstmal ausschalten, um ganz sicher zug ehen. console.log('########## MQTT SCRIPT-SAFETY-SHUTDOWN #########'); var obj = getObject("system.adapter.mqtt.0"); obj.common.enabled = false; setObject("system.adapter.mqtt.0", obj); timeout2 = setTimeout(function(){ console.log('########## MQTT SCRIPT-RESTART #########'); var obj = getObject("system.adapter.mqtt.0"); obj.common.enabled = true; setObject("system.adapter.mqtt.0", obj); }, 2500) } // Hier stehen die 5 sekunden }, 2500); });
-
So auf den schnellen Blick und per tapatalk sieht es ok aus, test Word es beweisen.
Du könntest den alive ja Mal auf false setzen um zu probieren
–-----------------------
Send from mobile device
-
Ne, funktioniert so leider nicht.
Sobald das Skript den Adapter ausschaltet, ruft dieses Event das Skript anscheinend nochmals auf (on: alive = false) , so dass sich eine Endlosschleife ergibt. Ich experimentiere heute Abend noch ein bisschen. Wenn ich eine Lösung finde, poste ich sie hier.
-
Ich blicks leider nicht.
Ich bin jetzt zurück bei ganz einfacher Alternative:
on({id: "system.adapter.mqtt.0.alive"/*mqtt.0.alive*/, val: false}, function (obj) { //Timeout, erst 5 sekunden nach status alive = false neustart initieren timeout = setTimeout(function () { // Adapter erstmal ausschalten, um ganz sicher zug ehen. console.log('########## MQTT SCRIPT-SAFETY-SHUTDOWN 3 #########'); var obj = getObject("system.adapter.mqtt.0"); obj.common.enabled = false; setObject("system.adapter.mqtt.0", obj); // Hier stehen die 5 sekunden }, 2500); timeout2 = setTimeout(function(){ console.log('########## MQTT SCRIPT-RESTART 3 #########'); var obj2 = getObject("system.adapter.mqtt.0"); obj2.common.enabled = true; setObject("system.adapter.mqtt.0", obj2); }, 5000); });
Das funktioniert, wenn ich den Adapter zum Beispiel einfach ausschalte.
Nach 2,5 Sek. Sicherheitsabschaltung.
Nach 5 Sek. Neustart.
Wenn ich aber das Objekt mqtt.0.alive per iobroker-Admin manuell auf FALSE setze, gerät er in irgendeine Art Schleife und ruft sich immer wieder selbst auf.
-
Das hier funktioniert, sowohl wenn man alive manuell auf false setzt, als auch wenn man den Play/Pause Button bei Adaptern drückt.
Sorry, jetzt ist deine Abfrage, ob aktiv oder nicht, nicht mehr drin und man kann den Adapter nicht mehr stoppen, ohne vorher das Skript zu deaktivieren.
Aber mir wurde es einfach zu kompliziert und undurchschaubar.
Aus irgendeinem Grund ruft ein manuelles Ändern alive = false das Skript 2 Mal auf - und stürzt in eine Endlosschleife.
Mit clearTimeout(Neustartschleife) funktioniert es irgendwie, auch wenn mir der Grund dafür nicht ganz klar ist.
Vielleicht wäre das ganze einfacher, wenn ich das Event bei connected = false aufrufen würde?
on({id: "system.adapter.mqtt.0.alive"/*mqtt.0.alive*/, val: false}, function (obj) { //Timeout: Nach 2,5 Sekunden Adapter abschalten timeout = setTimeout(function () { // Adapter erstmal ausschalten, um ganz sicher zug ehen. console.log('########## MQTT SCRIPT-SAFETY-SHUTDOWN 4 #########'); var obj = getObject("system.adapter.mqtt.0"); obj.common.enabled = false; setObject("system.adapter.mqtt.0", obj); }, 2500); //Timeout2: Nach 5 Sekunden Adapter neu starten timeout2 = setTimeout(function(){ console.log('########## MQTT SCRIPT-RESTART 4 #########'); var obj2 = getObject("system.adapter.mqtt.0"); obj2.common.enabled = true; setObject("system.adapter.mqtt.0", obj2); clearTimeout(timeout2); }, 5000); });
-
Ob connected oder alive der bessere Wert ist weiß ich nicht
Wenn es so läuft prima… Man kann es immer später komplexer machen wenn nötig
Send from mobile device
-
Ja, läuft.
Jetzt muss ich allerdings erst wieder warten, bis der eigentliche Fehler überhaupt auftritt.
Und dann sehen, ob das Skript ihn auch wirklich ausbügeln kann.
Davon abgesehen scheint das obige Skript praktisch zu sein, um einen iobroker-Adapter per Javascript-Adapter auf Aktivität zu testen und ihn ggf. neu zu starten oder zu beenden. Keine Garantie, aber falls mal jemand sowas sucht vlt. ein guter Startpunkt.
-
Das war der Grund warum ich gerne mit dir am Script gebastelt habe.
Kann bestimmt anderen helfen und hat Spass gemacht Mal lose davon das man es nicht brauche sollte ubdvein stabiler Adapter besser ist
–-----------------------
Send from mobile device
-
Noch ein Update:
Arteck hat mir ein Script gesckickt, wie er es macht:
Er fragt ab, ob sich bei den "connection"s etwas geändert hat (also ein Client an oder abgemeldet).
Wenn nichts mehr angemeldet ist, startet er MQTT neu (so verstehe ich das Script, kann sein, dass ich mich irre).
Ich lasse es jetzt mal laufen.
Konnte den Fehler bisher nicht reproduzieren, deshalb immer noch alles Spekulation. Aber bei ihm läuft es wohl.
// adapter neu starten var objPl = getObject('system.adapter.mqtt.0'); on({id: 'mqtt.0.info.connection', change: 'ne'}, function() { if (getObject('mqtt.0.info.connection').val === '') { objPl.common.enabled = false; // Adapter ausschalten setObject('system.adapter.mqtt.0', objPl, function (err) { if (err) console.log('Cannot write object: ' + err); }); setTimeout(function () { console.log('mqtt Reboot'); objPl.common.enabled = true; // Adapter einschalten setObject('system.adapter.mqtt.0', objPl); }, 1000 * 10); } });