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. Einsteigerfragen
  4. [gelöst] Docker (VM) Container mit ioB (LXC) restart

NEWS

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

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

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.2k

[gelöst] Docker (VM) Container mit ioB (LXC) restart

Geplant Angeheftet Gesperrt Verschoben Einsteigerfragen
15 Beiträge 3 Kommentatoren 744 Aufrufe 3 Watching
  • Ä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.
  • A australien

    Hallo zusammen,

    meine Gegebenheiten:

    • ioBroker auf Proxmox in eigenen LXC, 10.68.xx.yyy
    • Docker auf Proxmox in VM, 10.68.xx.zzz, darauf laufen der portainer.io und drei Container.

    Diese drei Container sollen nun mit dem ioB überwacht und ggf ein restart durchgeführt werden.

    Leider habe ich keinen Ahnung wie ich mit ioB auf den portainer.io zugreifen soll, gibt es da schon Lösungsansätze oder Ideen dazu?

    Danke Euch!

    OliverIOO Offline
    OliverIOO Offline
    OliverIO
    schrieb am zuletzt editiert von OliverIO
    #3

    @australien

    portainer hat eine api mit der du alles steuern kannst dazu musst du die als erstes ein access token holen

    https://docs.portainer.io/api/examples#authenticate-against-the-api-using-the-admin-account

    mit dem folgenden url schema und dem access token bspw dann auch ein container neu starten

    POST 
    http://10.68.xx.zzz:9000/api/endpoints/1/docker/containers/<container_id>/restart
    Authorization: Bearer <jwt>
    

    portainer reicht sozusagen die docker api mit http://10.68.xx.zzz:9000/api/endpoints/1/docker/ durch
    https://docs.docker.com/reference/api/engine/version/v1.41/#tag/Container/operation/ContainerRestart

    Meine Adapter und Widgets
    TVProgram, SqueezeboxRPC, OpenLiga, RSSFeed, MyTime,, pi-hole2, vis-json-template, skiinfo, vis-mapwidgets, vis-2-widgets-rssfeed
    Links im Profil

    A 1 Antwort Letzte Antwort
    0
    • OliverIOO OliverIO

      @australien

      portainer hat eine api mit der du alles steuern kannst dazu musst du die als erstes ein access token holen

      https://docs.portainer.io/api/examples#authenticate-against-the-api-using-the-admin-account

      mit dem folgenden url schema und dem access token bspw dann auch ein container neu starten

      POST 
      http://10.68.xx.zzz:9000/api/endpoints/1/docker/containers/<container_id>/restart
      Authorization: Bearer <jwt>
      

      portainer reicht sozusagen die docker api mit http://10.68.xx.zzz:9000/api/endpoints/1/docker/ durch
      https://docs.docker.com/reference/api/engine/version/v1.41/#tag/Container/operation/ContainerRestart

      A Offline
      A Offline
      australien
      schrieb am zuletzt editiert von
      #4

      @oliverio jetzt habe ich mir das angeschaut, leider sehe ich nur einen großen Bahnhof.
      Wie kann ich das in ioB umsetzten?
      Genauer gesagt, ein Container in portainer.io schmiert hinundwieder ab, dieser soll dann neu gestartet werden. Ersichtlich ist das insovern, das eingewisser DP keinen gültigen Wert liefert.

      OliverIOO 1 Antwort Letzte Antwort
      0
      • A australien

        @oliverio jetzt habe ich mir das angeschaut, leider sehe ich nur einen großen Bahnhof.
        Wie kann ich das in ioB umsetzten?
        Genauer gesagt, ein Container in portainer.io schmiert hinundwieder ab, dieser soll dann neu gestartet werden. Ersichtlich ist das insovern, das eingewisser DP keinen gültigen Wert liefert.

        OliverIOO Offline
        OliverIOO Offline
        OliverIO
        schrieb am zuletzt editiert von
        #5

        @australien

        Zunächst, der Fehler im Container sollte eigentlich als erstes analysiert und behoben werden, so dass solche Schritte nicht notwendig sein müssten. Das ist ja mehr oder weniger nichts anderes wie der Fußtritt gegen das Gerät.

        Ich hab mal ChatGPT gefragt, eine fertige Funktion für dich zu formulieren:

        // Restart a Docker container via Portainer API
        // Requires Node 18+ (native fetch) or node-fetch polyfill
        
        const PORTAINER_URL = "http://portainer.example.com:9000"; // deine Portainer-URL
        const API_TOKEN = "xxx_your_portainer_api_token_xxx";       // dein API-Token
        const ENDPOINT_ID = 1;                                      // meistens 1
        const CONTAINER_ID = "mein_container";                      // Container Name oder ID
        
        async function restartContainer() {
          const url = `${PORTAINER_URL}/api/endpoints/${ENDPOINT_ID}/docker/containers/${CONTAINER_ID}/restart`;
        
          try {
            const res = await fetch(url, {
              method: "POST",
              headers: {
                "Authorization": `Bearer ${API_TOKEN}`,
                "Content-Type": "application/json"
              }
            });
        
            if (res.ok) {
              console.log(`✅ Container "${CONTAINER_ID}" wurde erfolgreich neu gestartet.`);
            } else {
              const text = await res.text();
              console.error(`❌ Fehler: ${res.status} - ${text}`);
            }
          } catch (err) {
            console.error("⚠️ Netzwerkfehler:", err);
          }
        }
        
        restartContainer();
        
        

        Die Funktion sieht gut aus, hab sie aber selbst nicht getestet.
        Du musst eigentlich nur die ersten paar Zeilen ausfüllen.

        PORTAINER_URL Sollte eigentlich klar sein, die URL, mit der du den Container bei dir aufrufst.
        API_TOKEN den Token musst du dir im portainer erzeugen unter oben rechts auf deinen Anmeldenamen, dann mein myaccount auswählen.
        Da gibt es dann einen Abschnitt, wo du dir das erzeugen lassen kannst.
        CONTAINER_ID diese findest du im portainer auf der Statusseite des Containers ganz oben

        Meine Adapter und Widgets
        TVProgram, SqueezeboxRPC, OpenLiga, RSSFeed, MyTime,, pi-hole2, vis-json-template, skiinfo, vis-mapwidgets, vis-2-widgets-rssfeed
        Links im Profil

        A 1 Antwort Letzte Antwort
        0
        • OliverIOO OliverIO

          @australien

          Zunächst, der Fehler im Container sollte eigentlich als erstes analysiert und behoben werden, so dass solche Schritte nicht notwendig sein müssten. Das ist ja mehr oder weniger nichts anderes wie der Fußtritt gegen das Gerät.

          Ich hab mal ChatGPT gefragt, eine fertige Funktion für dich zu formulieren:

          // Restart a Docker container via Portainer API
          // Requires Node 18+ (native fetch) or node-fetch polyfill
          
          const PORTAINER_URL = "http://portainer.example.com:9000"; // deine Portainer-URL
          const API_TOKEN = "xxx_your_portainer_api_token_xxx";       // dein API-Token
          const ENDPOINT_ID = 1;                                      // meistens 1
          const CONTAINER_ID = "mein_container";                      // Container Name oder ID
          
          async function restartContainer() {
            const url = `${PORTAINER_URL}/api/endpoints/${ENDPOINT_ID}/docker/containers/${CONTAINER_ID}/restart`;
          
            try {
              const res = await fetch(url, {
                method: "POST",
                headers: {
                  "Authorization": `Bearer ${API_TOKEN}`,
                  "Content-Type": "application/json"
                }
              });
          
              if (res.ok) {
                console.log(`✅ Container "${CONTAINER_ID}" wurde erfolgreich neu gestartet.`);
              } else {
                const text = await res.text();
                console.error(`❌ Fehler: ${res.status} - ${text}`);
              }
            } catch (err) {
              console.error("⚠️ Netzwerkfehler:", err);
            }
          }
          
          restartContainer();
          
          

          Die Funktion sieht gut aus, hab sie aber selbst nicht getestet.
          Du musst eigentlich nur die ersten paar Zeilen ausfüllen.

          PORTAINER_URL Sollte eigentlich klar sein, die URL, mit der du den Container bei dir aufrufst.
          API_TOKEN den Token musst du dir im portainer erzeugen unter oben rechts auf deinen Anmeldenamen, dann mein myaccount auswählen.
          Da gibt es dann einen Abschnitt, wo du dir das erzeugen lassen kannst.
          CONTAINER_ID diese findest du im portainer auf der Statusseite des Containers ganz oben

          A Offline
          A Offline
          australien
          schrieb am zuletzt editiert von
          #6

          @oliverio danke für Deine Hilfe!

          Ich habe mich nun auch etwas mit KI und dem Thema beschäftigt.
          Leider kann ich meine EndpointID nirgends wo finden und wollte dies mit folgendem finden lassen:

          const https = require('https');
          
          // Konfiguration
          const PORTAINER_HOST = '10.68.xx.yy';
          const PORTAINER_PORT = 9443;
          const API_TOKEN = 'XxXxXxXx'; // Hier deinen gültigen Token eintragen
          const ENDPOINT_ID = 1;
          const CONTAINER_ID = 'Cont_ID';
          
          // Funktion, um Container neu zu starten
          function restartContainer() {
              const options = {
                  hostname: PORTAINER_HOST,
                  port: PORTAINER_PORT,
                  path: `/api/endpoints/${ENDPOINT_ID}/docker/containers/${CONTAINER_ID}/restart`,
                  method: 'POST',
                  headers: {
                      "Authorization": `Bearer ${API_TOKEN}`,
                      "Content-Type": "application/json"
                  },
                  rejectUnauthorized: false // Self-signed Zertifikat akzeptieren
              };
          
              const req = https.request(options, (res) => {
                  let data = '';
                  res.on('data', chunk => data += chunk);
                  res.on('end', () => {
                      if (res.statusCode >= 200 && res.statusCode < 300) {
                          console.log(`✅ Container "${CONTAINER_ID}" wurde erfolgreich neu gestartet.`);
                      } else {
                          console.error(`❌ Fehler beim Neustart: ${res.statusCode} - ${data}`);
                      }
                  });
              });
          
              req.on('error', (err) => {
                  console.error(`⚠️ Netzwerkfehler: ${err}`);
              });
          
              req.end();
          }
          
          // Direkt beim Start ausführen (optional)
          restartContainer();
          
          

          jetzt kann ich Tokens erstellen, aber diese werden sofort immer als falsch identifiziert.
          ich gehe folgenden Weg:
          User - my account - access token

          meine Portainer Vers: Community Edition 2.33.0.LTS

          OliverIOO 1 Antwort Letzte Antwort
          0
          • A australien

            @oliverio danke für Deine Hilfe!

            Ich habe mich nun auch etwas mit KI und dem Thema beschäftigt.
            Leider kann ich meine EndpointID nirgends wo finden und wollte dies mit folgendem finden lassen:

            const https = require('https');
            
            // Konfiguration
            const PORTAINER_HOST = '10.68.xx.yy';
            const PORTAINER_PORT = 9443;
            const API_TOKEN = 'XxXxXxXx'; // Hier deinen gültigen Token eintragen
            const ENDPOINT_ID = 1;
            const CONTAINER_ID = 'Cont_ID';
            
            // Funktion, um Container neu zu starten
            function restartContainer() {
                const options = {
                    hostname: PORTAINER_HOST,
                    port: PORTAINER_PORT,
                    path: `/api/endpoints/${ENDPOINT_ID}/docker/containers/${CONTAINER_ID}/restart`,
                    method: 'POST',
                    headers: {
                        "Authorization": `Bearer ${API_TOKEN}`,
                        "Content-Type": "application/json"
                    },
                    rejectUnauthorized: false // Self-signed Zertifikat akzeptieren
                };
            
                const req = https.request(options, (res) => {
                    let data = '';
                    res.on('data', chunk => data += chunk);
                    res.on('end', () => {
                        if (res.statusCode >= 200 && res.statusCode < 300) {
                            console.log(`✅ Container "${CONTAINER_ID}" wurde erfolgreich neu gestartet.`);
                        } else {
                            console.error(`❌ Fehler beim Neustart: ${res.statusCode} - ${data}`);
                        }
                    });
                });
            
                req.on('error', (err) => {
                    console.error(`⚠️ Netzwerkfehler: ${err}`);
                });
            
                req.end();
            }
            
            // Direkt beim Start ausführen (optional)
            restartContainer();
            
            

            jetzt kann ich Tokens erstellen, aber diese werden sofort immer als falsch identifiziert.
            ich gehe folgenden Weg:
            User - my account - access token

            meine Portainer Vers: Community Edition 2.33.0.LTS

            OliverIOO Offline
            OliverIOO Offline
            OliverIO
            schrieb am zuletzt editiert von OliverIO
            #7

            @australien

            ja da hat sich die ki verschwurbelt
            hier eine neue skript version. diesmal habe ich sie selbst ausprobiert
            ich habe mal meine daten drin gelassen, damit du ein gefühl bekommst was da drin stehen könnte.
            das login wurde nun auf userid/passwort umgestellt.
            die endpoint id lass bitte auf 1, entweder ist das die api version oder die environment id, da du wahrscheinlich nur ein system mit portainer administriest, wird das auch bei dir 1 sein.

            // Nur Node http Modul, ganz einfach
            const http = require('http');
            
            // Konfiguration:
            const PORTAINER_HOST = '192.168.1.40';
            const PORTAINER_PORT = 9100;
            const PORTAINER_USERNAME = 'admin';
            const PORTAINER_PASSWORD = 'adminadmin';
            const PORTAINER_ENDPOINT_ID = '1';
            const PORTAINER_CONTAINER_ID = '681ada44f1d73fcc8645c8b623d7f724e860632ca9bc6bbb9e9bf1f06451e32d';
            const PORTAINER_RESTART_TIMEOUT = '10';
            
            function httpRequest(path, method, headers, body, callback) {
                const options = {
                    hostname: PORTAINER_HOST,
                    port: PORTAINER_PORT,
                    path,
                    method,
                    headers,
                };
            
                const req = http.request(options, (res) => {
                    let data = '';
                    res.on('data', (chunk) => (data += chunk));
                    res.on('end', () => {
                        callback(null, { statusCode: res.statusCode, body: data });
                    });
                });
            
                req.on('error', (err) => callback(err));
            
                if (body) req.write(body);
                req.end();
            }
            
            function loginAndGetJWT(cb) {
                const body = JSON.stringify({ Username: PORTAINER_USERNAME, Password: PORTAINER_PASSWORD });
                httpRequest(
                    '/api/auth',
                    'POST',
                    {
                        'Content-Type': 'application/json',
                        'Content-Length': Buffer.byteLength(body),
                    },
                    body,
                    (err, res) => {
                        if (err) return cb(err);
                        if (res.statusCode !== 200) return cb(new Error('Login fehlgeschlagen: ' + res.body));
                        let data;
                        try {
                            data = JSON.parse(res.body);
                        } catch (e) {
                            return cb(e);
                        }
                        if (!data.jwt) return cb(new Error('Kein JWT im Response.'));
                        cb(null, data.jwt);
                    }
                );
            }
            
            function restartContainer(jwt, cb) {
                const path =
                    `/api/endpoints/${PORTAINER_ENDPOINT_ID}/docker/containers/${PORTAINER_CONTAINER_ID}/restart` +
                    `?t=${PORTAINER_RESTART_TIMEOUT}`;
            
                httpRequest(
                    path,
                    'POST',
                    { Authorization: 'Bearer ' + jwt },
                    null,
                    (err, res) => {
                        if (err) return cb(err);
                        if (res.statusCode !== 204) return cb(new Error('Restart fehlgeschlagen: ' + res.body));
                        cb(null);
                    }
                );
            }
            
            // Ablauf:
            loginAndGetJWT((err, jwt) => {
                if (err) return console.error('Login Fehler:', err.message);
                restartContainer(jwt, (err2) => {
                    if (err2) return console.error('Restart Fehler:', err2.message);
                    console.log(`✅ Container ${PORTAINER_CONTAINER_ID} neu gestartet.`);
                });
            });
            
            
            

            Meine Adapter und Widgets
            TVProgram, SqueezeboxRPC, OpenLiga, RSSFeed, MyTime,, pi-hole2, vis-json-template, skiinfo, vis-mapwidgets, vis-2-widgets-rssfeed
            Links im Profil

            A 1 Antwort Letzte Antwort
            0
            • OliverIOO OliverIO

              @australien

              ja da hat sich die ki verschwurbelt
              hier eine neue skript version. diesmal habe ich sie selbst ausprobiert
              ich habe mal meine daten drin gelassen, damit du ein gefühl bekommst was da drin stehen könnte.
              das login wurde nun auf userid/passwort umgestellt.
              die endpoint id lass bitte auf 1, entweder ist das die api version oder die environment id, da du wahrscheinlich nur ein system mit portainer administriest, wird das auch bei dir 1 sein.

              // Nur Node http Modul, ganz einfach
              const http = require('http');
              
              // Konfiguration:
              const PORTAINER_HOST = '192.168.1.40';
              const PORTAINER_PORT = 9100;
              const PORTAINER_USERNAME = 'admin';
              const PORTAINER_PASSWORD = 'adminadmin';
              const PORTAINER_ENDPOINT_ID = '1';
              const PORTAINER_CONTAINER_ID = '681ada44f1d73fcc8645c8b623d7f724e860632ca9bc6bbb9e9bf1f06451e32d';
              const PORTAINER_RESTART_TIMEOUT = '10';
              
              function httpRequest(path, method, headers, body, callback) {
                  const options = {
                      hostname: PORTAINER_HOST,
                      port: PORTAINER_PORT,
                      path,
                      method,
                      headers,
                  };
              
                  const req = http.request(options, (res) => {
                      let data = '';
                      res.on('data', (chunk) => (data += chunk));
                      res.on('end', () => {
                          callback(null, { statusCode: res.statusCode, body: data });
                      });
                  });
              
                  req.on('error', (err) => callback(err));
              
                  if (body) req.write(body);
                  req.end();
              }
              
              function loginAndGetJWT(cb) {
                  const body = JSON.stringify({ Username: PORTAINER_USERNAME, Password: PORTAINER_PASSWORD });
                  httpRequest(
                      '/api/auth',
                      'POST',
                      {
                          'Content-Type': 'application/json',
                          'Content-Length': Buffer.byteLength(body),
                      },
                      body,
                      (err, res) => {
                          if (err) return cb(err);
                          if (res.statusCode !== 200) return cb(new Error('Login fehlgeschlagen: ' + res.body));
                          let data;
                          try {
                              data = JSON.parse(res.body);
                          } catch (e) {
                              return cb(e);
                          }
                          if (!data.jwt) return cb(new Error('Kein JWT im Response.'));
                          cb(null, data.jwt);
                      }
                  );
              }
              
              function restartContainer(jwt, cb) {
                  const path =
                      `/api/endpoints/${PORTAINER_ENDPOINT_ID}/docker/containers/${PORTAINER_CONTAINER_ID}/restart` +
                      `?t=${PORTAINER_RESTART_TIMEOUT}`;
              
                  httpRequest(
                      path,
                      'POST',
                      { Authorization: 'Bearer ' + jwt },
                      null,
                      (err, res) => {
                          if (err) return cb(err);
                          if (res.statusCode !== 204) return cb(new Error('Restart fehlgeschlagen: ' + res.body));
                          cb(null);
                      }
                  );
              }
              
              // Ablauf:
              loginAndGetJWT((err, jwt) => {
                  if (err) return console.error('Login Fehler:', err.message);
                  restartContainer(jwt, (err2) => {
                      if (err2) return console.error('Restart Fehler:', err2.message);
                      console.log(`✅ Container ${PORTAINER_CONTAINER_ID} neu gestartet.`);
                  });
              });
              
              
              
              A Offline
              A Offline
              australien
              schrieb am zuletzt editiert von australien
              #8

              @oliverio Danke, jetzt hab ich es hin bekommen, obwohl es erst funktioniert hat, als ich als EndpointId 3 eingegeben hatte.

              Jetzt noch eine andere Frage dazu, gibt es einen Möglichkeit den Status (running) des containers abzufragen?

              OliverIOO 1 Antwort Letzte Antwort
              0
              • A australien

                @oliverio Danke, jetzt hab ich es hin bekommen, obwohl es erst funktioniert hat, als ich als EndpointId 3 eingegeben hatte.

                Jetzt noch eine andere Frage dazu, gibt es einen Möglichkeit den Status (running) des containers abzufragen?

                OliverIOO Offline
                OliverIOO Offline
                OliverIO
                schrieb am zuletzt editiert von
                #9

                @australien

                Portainer spiegelt dir die docker api nach draußen.
                Daher kannst du alle api Endpunkte die docker bereitstellt in dieser Art abfragen.

                Diese Information dürfte hier sein

                https://docs.docker.com/reference/api/engine/version/v1.51/#tag/Container/operation/ContainerInspect

                Das mit dem endpoint id ist interessant. Wusste ich auch nicht

                Meine Adapter und Widgets
                TVProgram, SqueezeboxRPC, OpenLiga, RSSFeed, MyTime,, pi-hole2, vis-json-template, skiinfo, vis-mapwidgets, vis-2-widgets-rssfeed
                Links im Profil

                A 1 Antwort Letzte Antwort
                0
                • OliverIOO OliverIO

                  @australien

                  Portainer spiegelt dir die docker api nach draußen.
                  Daher kannst du alle api Endpunkte die docker bereitstellt in dieser Art abfragen.

                  Diese Information dürfte hier sein

                  https://docs.docker.com/reference/api/engine/version/v1.51/#tag/Container/operation/ContainerInspect

                  Das mit dem endpoint id ist interessant. Wusste ich auch nicht

                  A Offline
                  A Offline
                  australien
                  schrieb am zuletzt editiert von australien
                  #10

                  @oliverio habe das jetzt so gelöst.
                  Wenn der Container nicht läuft, wird er restarted.

                  Danke nocheinmal für deine Hilfe!

                  const http = require('http');
                  
                  // Konfiguration
                  const PORTAINER_HOST = '10.68.xx.yy';
                  const PORTAINER_PORT = 9000;
                  const PORTAINER_USERNAME = 'admin';
                  const PORTAINER_PASSWORD = 'passwort';
                  const PORTAINER_ENDPOINT_ID = '3';      // standard sollte 1 sein, ersichtlich in der url yy:9000/#!/3/docker/containers
                  const PORTAINER_CONTAINER_ID = 'fbb9d130592c7edb96a4a71dc067721c1989bb3a27df';
                  const PORTAINER_RESTART_TIMEOUT = '10';
                  const INTERVAL_MINUTES = 10;
                  
                  const DEBUG = false; // <-- true = loggt alles, false = keine Logs
                  
                  function debugLog(...args) {
                      if (DEBUG) console.log(...args);
                  }
                  
                  function httpRequest(path, method, headers, body, callback) {
                      const options = {
                          hostname: PORTAINER_HOST,
                          port: PORTAINER_PORT,
                          path,
                          method,
                          headers,
                      };
                  
                      const req = http.request(options, (res) => {
                          let data = '';
                          res.on('data', chunk => data += chunk);
                          res.on('end', () => callback(null, { statusCode: res.statusCode, body: data }));
                      });
                  
                      req.on('error', err => callback(err));
                      if (body) req.write(body);
                      req.end();
                  }
                  
                  function loginAndGetJWT(cb) {
                      const body = JSON.stringify({ Username: PORTAINER_USERNAME, Password: PORTAINER_PASSWORD });
                      httpRequest('/api/auth', 'POST', {
                          'Content-Type': 'application/json',
                          'Content-Length': Buffer.byteLength(body),
                      }, body, (err, res) => {
                          if (err) return cb(err);
                          if (res.statusCode !== 200) return cb(new Error('Login fehlgeschlagen: ' + res.body));
                          let data;
                          try { data = JSON.parse(res.body); } catch (e) { return cb(e); }
                          if (!data.jwt) return cb(new Error('Kein JWT im Response.'));
                          debugLog('✅ Login erfolgreich, JWT erhalten.');
                          cb(null, data.jwt);
                      });
                  }
                  
                  function restartContainer(jwt, cb) {
                      const path = `/api/endpoints/${PORTAINER_ENDPOINT_ID}/docker/containers/${PORTAINER_CONTAINER_ID}/restart?t=${PORTAINER_RESTART_TIMEOUT}`;
                      httpRequest(path, 'POST', { Authorization: 'Bearer ' + jwt }, null, (err, res) => {
                          if (err) return cb(err);
                          if (res.statusCode !== 204) return cb(new Error('Restart fehlgeschlagen: ' + res.body));
                          debugLog(`✅ Container ${PORTAINER_CONTAINER_ID} neu gestartet.`);
                          cb(null);
                      });
                  }
                  
                  function checkAndRestartContainer(jwt) {
                      const path = `/api/endpoints/${PORTAINER_ENDPOINT_ID}/docker/containers/${PORTAINER_CONTAINER_ID}/json`;
                      debugLog('Requesting:', path);
                  
                      httpRequest(path, 'GET', { Authorization: 'Bearer ' + jwt }, null, (err, res) => {
                          if (err) return debugLog('Status Fehler:', err.message);
                  
                          let data;
                          try { data = JSON.parse(res.body); } 
                          catch (e) { return debugLog('Parsing Fehler:', e.message); }
                  
                          if (!data.State || data.State.Running !== true) {
                              debugLog('Container läuft nicht. Starte neu...');
                              restartContainer(jwt, (err2) => {
                                  if (err2) return debugLog('Restart Fehler:', err2.message);
                              });
                          } else {
                              debugLog(`✅ Container ${PORTAINER_CONTAINER_ID} läuft normal.`);
                          }
                      });
                  }
                  
                  // Ablauf alle 10 Minuten
                  loginAndGetJWT((err, jwt) => {
                      if (err) return console.error('Login Fehler:', err.message);
                  
                      // Sofort prüfen
                      checkAndRestartContainer(jwt);
                  
                      // Intervall setzen
                      setInterval(() => checkAndRestartContainer(jwt), INTERVAL_MINUTES * 60 * 1000);
                  });
                  
                  
                  OliverIOO 2 Antworten Letzte Antwort
                  0
                  • A australien

                    @oliverio habe das jetzt so gelöst.
                    Wenn der Container nicht läuft, wird er restarted.

                    Danke nocheinmal für deine Hilfe!

                    const http = require('http');
                    
                    // Konfiguration
                    const PORTAINER_HOST = '10.68.xx.yy';
                    const PORTAINER_PORT = 9000;
                    const PORTAINER_USERNAME = 'admin';
                    const PORTAINER_PASSWORD = 'passwort';
                    const PORTAINER_ENDPOINT_ID = '3';      // standard sollte 1 sein, ersichtlich in der url yy:9000/#!/3/docker/containers
                    const PORTAINER_CONTAINER_ID = 'fbb9d130592c7edb96a4a71dc067721c1989bb3a27df';
                    const PORTAINER_RESTART_TIMEOUT = '10';
                    const INTERVAL_MINUTES = 10;
                    
                    const DEBUG = false; // <-- true = loggt alles, false = keine Logs
                    
                    function debugLog(...args) {
                        if (DEBUG) console.log(...args);
                    }
                    
                    function httpRequest(path, method, headers, body, callback) {
                        const options = {
                            hostname: PORTAINER_HOST,
                            port: PORTAINER_PORT,
                            path,
                            method,
                            headers,
                        };
                    
                        const req = http.request(options, (res) => {
                            let data = '';
                            res.on('data', chunk => data += chunk);
                            res.on('end', () => callback(null, { statusCode: res.statusCode, body: data }));
                        });
                    
                        req.on('error', err => callback(err));
                        if (body) req.write(body);
                        req.end();
                    }
                    
                    function loginAndGetJWT(cb) {
                        const body = JSON.stringify({ Username: PORTAINER_USERNAME, Password: PORTAINER_PASSWORD });
                        httpRequest('/api/auth', 'POST', {
                            'Content-Type': 'application/json',
                            'Content-Length': Buffer.byteLength(body),
                        }, body, (err, res) => {
                            if (err) return cb(err);
                            if (res.statusCode !== 200) return cb(new Error('Login fehlgeschlagen: ' + res.body));
                            let data;
                            try { data = JSON.parse(res.body); } catch (e) { return cb(e); }
                            if (!data.jwt) return cb(new Error('Kein JWT im Response.'));
                            debugLog('✅ Login erfolgreich, JWT erhalten.');
                            cb(null, data.jwt);
                        });
                    }
                    
                    function restartContainer(jwt, cb) {
                        const path = `/api/endpoints/${PORTAINER_ENDPOINT_ID}/docker/containers/${PORTAINER_CONTAINER_ID}/restart?t=${PORTAINER_RESTART_TIMEOUT}`;
                        httpRequest(path, 'POST', { Authorization: 'Bearer ' + jwt }, null, (err, res) => {
                            if (err) return cb(err);
                            if (res.statusCode !== 204) return cb(new Error('Restart fehlgeschlagen: ' + res.body));
                            debugLog(`✅ Container ${PORTAINER_CONTAINER_ID} neu gestartet.`);
                            cb(null);
                        });
                    }
                    
                    function checkAndRestartContainer(jwt) {
                        const path = `/api/endpoints/${PORTAINER_ENDPOINT_ID}/docker/containers/${PORTAINER_CONTAINER_ID}/json`;
                        debugLog('Requesting:', path);
                    
                        httpRequest(path, 'GET', { Authorization: 'Bearer ' + jwt }, null, (err, res) => {
                            if (err) return debugLog('Status Fehler:', err.message);
                    
                            let data;
                            try { data = JSON.parse(res.body); } 
                            catch (e) { return debugLog('Parsing Fehler:', e.message); }
                    
                            if (!data.State || data.State.Running !== true) {
                                debugLog('Container läuft nicht. Starte neu...');
                                restartContainer(jwt, (err2) => {
                                    if (err2) return debugLog('Restart Fehler:', err2.message);
                                });
                            } else {
                                debugLog(`✅ Container ${PORTAINER_CONTAINER_ID} läuft normal.`);
                            }
                        });
                    }
                    
                    // Ablauf alle 10 Minuten
                    loginAndGetJWT((err, jwt) => {
                        if (err) return console.error('Login Fehler:', err.message);
                    
                        // Sofort prüfen
                        checkAndRestartContainer(jwt);
                    
                        // Intervall setzen
                        setInterval(() => checkAndRestartContainer(jwt), INTERVAL_MINUTES * 60 * 1000);
                    });
                    
                    
                    OliverIOO Offline
                    OliverIOO Offline
                    OliverIO
                    schrieb am zuletzt editiert von
                    #11

                    @australien

                    super,
                    danke das du deinen code zum abschluss nochmal gepostet hast,
                    dann können andere den wiederverwenden und ggfs erweitern.

                    Meine Adapter und Widgets
                    TVProgram, SqueezeboxRPC, OpenLiga, RSSFeed, MyTime,, pi-hole2, vis-json-template, skiinfo, vis-mapwidgets, vis-2-widgets-rssfeed
                    Links im Profil

                    1 Antwort Letzte Antwort
                    1
                    • A australien

                      @oliverio habe das jetzt so gelöst.
                      Wenn der Container nicht läuft, wird er restarted.

                      Danke nocheinmal für deine Hilfe!

                      const http = require('http');
                      
                      // Konfiguration
                      const PORTAINER_HOST = '10.68.xx.yy';
                      const PORTAINER_PORT = 9000;
                      const PORTAINER_USERNAME = 'admin';
                      const PORTAINER_PASSWORD = 'passwort';
                      const PORTAINER_ENDPOINT_ID = '3';      // standard sollte 1 sein, ersichtlich in der url yy:9000/#!/3/docker/containers
                      const PORTAINER_CONTAINER_ID = 'fbb9d130592c7edb96a4a71dc067721c1989bb3a27df';
                      const PORTAINER_RESTART_TIMEOUT = '10';
                      const INTERVAL_MINUTES = 10;
                      
                      const DEBUG = false; // <-- true = loggt alles, false = keine Logs
                      
                      function debugLog(...args) {
                          if (DEBUG) console.log(...args);
                      }
                      
                      function httpRequest(path, method, headers, body, callback) {
                          const options = {
                              hostname: PORTAINER_HOST,
                              port: PORTAINER_PORT,
                              path,
                              method,
                              headers,
                          };
                      
                          const req = http.request(options, (res) => {
                              let data = '';
                              res.on('data', chunk => data += chunk);
                              res.on('end', () => callback(null, { statusCode: res.statusCode, body: data }));
                          });
                      
                          req.on('error', err => callback(err));
                          if (body) req.write(body);
                          req.end();
                      }
                      
                      function loginAndGetJWT(cb) {
                          const body = JSON.stringify({ Username: PORTAINER_USERNAME, Password: PORTAINER_PASSWORD });
                          httpRequest('/api/auth', 'POST', {
                              'Content-Type': 'application/json',
                              'Content-Length': Buffer.byteLength(body),
                          }, body, (err, res) => {
                              if (err) return cb(err);
                              if (res.statusCode !== 200) return cb(new Error('Login fehlgeschlagen: ' + res.body));
                              let data;
                              try { data = JSON.parse(res.body); } catch (e) { return cb(e); }
                              if (!data.jwt) return cb(new Error('Kein JWT im Response.'));
                              debugLog('✅ Login erfolgreich, JWT erhalten.');
                              cb(null, data.jwt);
                          });
                      }
                      
                      function restartContainer(jwt, cb) {
                          const path = `/api/endpoints/${PORTAINER_ENDPOINT_ID}/docker/containers/${PORTAINER_CONTAINER_ID}/restart?t=${PORTAINER_RESTART_TIMEOUT}`;
                          httpRequest(path, 'POST', { Authorization: 'Bearer ' + jwt }, null, (err, res) => {
                              if (err) return cb(err);
                              if (res.statusCode !== 204) return cb(new Error('Restart fehlgeschlagen: ' + res.body));
                              debugLog(`✅ Container ${PORTAINER_CONTAINER_ID} neu gestartet.`);
                              cb(null);
                          });
                      }
                      
                      function checkAndRestartContainer(jwt) {
                          const path = `/api/endpoints/${PORTAINER_ENDPOINT_ID}/docker/containers/${PORTAINER_CONTAINER_ID}/json`;
                          debugLog('Requesting:', path);
                      
                          httpRequest(path, 'GET', { Authorization: 'Bearer ' + jwt }, null, (err, res) => {
                              if (err) return debugLog('Status Fehler:', err.message);
                      
                              let data;
                              try { data = JSON.parse(res.body); } 
                              catch (e) { return debugLog('Parsing Fehler:', e.message); }
                      
                              if (!data.State || data.State.Running !== true) {
                                  debugLog('Container läuft nicht. Starte neu...');
                                  restartContainer(jwt, (err2) => {
                                      if (err2) return debugLog('Restart Fehler:', err2.message);
                                  });
                              } else {
                                  debugLog(`✅ Container ${PORTAINER_CONTAINER_ID} läuft normal.`);
                              }
                          });
                      }
                      
                      // Ablauf alle 10 Minuten
                      loginAndGetJWT((err, jwt) => {
                          if (err) return console.error('Login Fehler:', err.message);
                      
                          // Sofort prüfen
                          checkAndRestartContainer(jwt);
                      
                          // Intervall setzen
                          setInterval(() => checkAndRestartContainer(jwt), INTERVAL_MINUTES * 60 * 1000);
                      });
                      
                      
                      OliverIOO Offline
                      OliverIOO Offline
                      OliverIO
                      schrieb am zuletzt editiert von
                      #12

                      @australien
                      mach bitte bei endpoint id nochmal einen kommentar hin, das man das ausprobieren muss bzw evtl so nachgeschaut werden kann

                      ae8ef6e4-67a1-4be1-a350-e378a90b90fa-image.png

                      kannst du das bei dir verifizieren? da müsste dann bei dir eine 3 stehen

                      Meine Adapter und Widgets
                      TVProgram, SqueezeboxRPC, OpenLiga, RSSFeed, MyTime,, pi-hole2, vis-json-template, skiinfo, vis-mapwidgets, vis-2-widgets-rssfeed
                      Links im Profil

                      A 1 Antwort Letzte Antwort
                      0
                      • OliverIOO OliverIO

                        @australien
                        mach bitte bei endpoint id nochmal einen kommentar hin, das man das ausprobieren muss bzw evtl so nachgeschaut werden kann

                        ae8ef6e4-67a1-4be1-a350-e378a90b90fa-image.png

                        kannst du das bei dir verifizieren? da müsste dann bei dir eine 3 stehen

                        A Offline
                        A Offline
                        australien
                        schrieb am zuletzt editiert von australien
                        #13

                        @oliverio bei mir steht tatsächlich 3

                        60:9000/#!/3/docker/containers
                        
                        OliverIOO 1 Antwort Letzte Antwort
                        0
                        • A australien

                          @oliverio bei mir steht tatsächlich 3

                          60:9000/#!/3/docker/containers
                          
                          OliverIOO Offline
                          OliverIOO Offline
                          OliverIO
                          schrieb am zuletzt editiert von OliverIO
                          #14

                          @australien

                          ok dann ist es die id des environments
                          also das was man am anfang, nach dem login im portainer auswählt.

                          Meine Adapter und Widgets
                          TVProgram, SqueezeboxRPC, OpenLiga, RSSFeed, MyTime,, pi-hole2, vis-json-template, skiinfo, vis-mapwidgets, vis-2-widgets-rssfeed
                          Links im Profil

                          A 1 Antwort Letzte Antwort
                          0
                          • OliverIOO OliverIO

                            @australien

                            ok dann ist es die id des environments
                            also das was man am anfang, nach dem login im portainer auswählt.

                            A Offline
                            A Offline
                            australien
                            schrieb am zuletzt editiert von
                            #15

                            @oliverio hab es als Kommentar hinzugefügt

                            1 Antwort Letzte Antwort
                            1
                            Antworten
                            • In einem neuen Thema antworten
                            Anmelden zum Antworten
                            • Älteste zuerst
                            • Neuste zuerst
                            • Meiste Stimmen


                            Support us

                            ioBroker
                            Community Adapters
                            Donate

                            727

                            Online

                            32.6k

                            Benutzer

                            82.2k

                            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