Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • 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

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. ioBroker Allgemein
  4. [gelöst] MQTT Server Restart?

NEWS

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    16
    1
    1.6k

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    13
    1
    864

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.1k

[gelöst] MQTT Server Restart?

Geplant Angeheftet Gesperrt Verschoben ioBroker Allgemein
41 Beiträge 3 Kommentatoren 6.6k Aufrufe
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • DutchmanD Offline
    DutchmanD Offline
    Dutchman
    Developer Most Active Administrators
    schrieb am zuletzt editiert von
    #32

    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

    1 Antwort Letzte Antwort
    0
    • ? Offline
      ? Offline
      Ein ehemaliger Benutzer
      schrieb am zuletzt editiert von
      #33
      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);    
      });
      
      
      1 Antwort Letzte Antwort
      0
      • DutchmanD Offline
        DutchmanD Offline
        Dutchman
        Developer Most Active Administrators
        schrieb am zuletzt editiert von
        #34

        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

        1 Antwort Letzte Antwort
        0
        • ? Offline
          ? Offline
          Ein ehemaliger Benutzer
          schrieb am zuletzt editiert von
          #35

          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.

          1 Antwort Letzte Antwort
          0
          • ? Offline
            ? Offline
            Ein ehemaliger Benutzer
            schrieb am zuletzt editiert von
            #36

            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.

            1 Antwort Letzte Antwort
            0
            • ? Offline
              ? Offline
              Ein ehemaliger Benutzer
              schrieb am zuletzt editiert von
              #37

              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);
              });
              
              
              1 Antwort Letzte Antwort
              0
              • DutchmanD Offline
                DutchmanD Offline
                Dutchman
                Developer Most Active Administrators
                schrieb am zuletzt editiert von
                #38

                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

                1 Antwort Letzte Antwort
                0
                • ? Offline
                  ? Offline
                  Ein ehemaliger Benutzer
                  schrieb am zuletzt editiert von
                  #39

                  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.

                  1 Antwort Letzte Antwort
                  0
                  • DutchmanD Offline
                    DutchmanD Offline
                    Dutchman
                    Developer Most Active Administrators
                    schrieb am zuletzt editiert von
                    #40

                    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 :D

                    –-----------------------

                    Send from mobile device

                    1 Antwort Letzte Antwort
                    0
                    • ? Offline
                      ? Offline
                      Ein ehemaliger Benutzer
                      schrieb am zuletzt editiert von
                      #41

                      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);     
                          }
                      
                      });
                      
                      
                      1 Antwort Letzte Antwort
                      0
                      Antworten
                      • In einem neuen Thema antworten
                      Anmelden zum Antworten
                      • Älteste zuerst
                      • Neuste zuerst
                      • Meiste Stimmen


                      Support us

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

                      847

                      Online

                      32.6k

                      Benutzer

                      82.1k

                      Themen

                      1.3m

                      Beiträge
                      Community
                      Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                      ioBroker Community 2014-2025
                      logo
                      • Anmelden

                      • Du hast noch kein Konto? Registrieren

                      • Anmelden oder registrieren, um zu suchen
                      • Erster Beitrag
                        Letzter Beitrag
                      0
                      • Home
                      • Aktuell
                      • Tags
                      • Ungelesen 0
                      • Kategorien
                      • Unreplied
                      • Beliebt
                      • GitHub
                      • Docu
                      • Hilfe