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. Skripten / Logik
  4. [Gelöst] Shell Script lässt sich nicht starten

NEWS

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    12
    1
    302

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

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

[Gelöst] Shell Script lässt sich nicht starten

Geplant Angeheftet Gesperrt Verschoben Skripten / Logik
8 Beiträge 4 Kommentatoren 2.7k 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.
  • PeoplesP Offline
    PeoplesP Offline
    Peoples
    schrieb am zuletzt editiert von
    #1

    Hi,

    ich versuche via Javascript ein Shell-Script zu starten und habe als Vorlage das Yeelight Script aus dem Forum genommen, doch irgendwie klappt das überhaupt nicht.

    Folgender Befehl in Putty funktioniert bestens:

    sh backup.sh Dateiname 10 Dateiverzeichnis
    
    
    • Dateiname

    • 10

    • Dateiverzeichnis

    sind Variablen die ich beim Aufruf der backup.sh mit übergeben muss.

    Hier der Javascript Teil der das ganze aufrufen soll:

    // -----------------------------------------------------------------------------
    // allgemeine Variablen
    // -----------------------------------------------------------------------------
    var logging = true;                                        // Logging on/off
    var instanz = 'javascript.0';  instanz = instanz + '.';     // 
                                                                //
    var pfad0 =   'System.Iobroker.Backup.';                    // Pfad innerhalb der Instanz - Status allgemien
    
    var bash_script = 'bash /opt/iobroker/backup.sh ';          // Pfad zu backup.sh Datei
    
    var loeschen_nach = '10 ';
    var kopie_pfad = 'Dateipfad ';
    var dateiname_anhang='Dateiname ';
    // -----------------------------------------------------------------------------
    // Objekte
    // -----------------------------------------------------------------------------
    
    function backup_erstellen(name, zeit, pfad) {
            exec(([bash_script ,name, zeit, pfad].join('')));
            if(logging) console.log("exec: " + ([bash_script ,name, zeit, pfad].join('')));
    }
    
    backup_erstellen(dateiname_anhang, loeschen_nach, kopie_pfad);
    

    Der Befehlaufruf von exec hab ich übernommen von eben dem genannten Yeelight-Script.

    Hat vielleicht einer Ahnung warum das nicht funktioniert? Und kann man den Befehlaufruf mitloggen wenn man Putty mitlaufen lässt?

    Danke

    Steffen

    Ich beantworte keine Fragen zu Themen via PN

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

      Was sagt dein Log und welche js-adapter Version hast du drauf?

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

      Send from mobile device

      Das schöne ios hat Auto Korrektur zum k****

      Wer Schreibfehler findet darf sie behalten oder auf eBay verkaufen, mindest Umsatz 10% für die community

      1 Antwort Letzte Antwort
      0
      • PeoplesP Offline
        PeoplesP Offline
        Peoples
        schrieb am zuletzt editiert von
        #3

        der Log von Iobroker sagt:

        javascript.0	2017-12-22 23:46:03.937	info	script.js.Backup_Script: exec: bash /opt/iobroker/backup.sh testname 10
        

        und die Javascript Version ist die 3.4.0

        Da mein Yeelight Script aber funktioniert denke ich nicht dass die Javascriptversion das Problem ist.

        Gruß

        Steffen

        Ich beantworte keine Fragen zu Themen via PN

        1 Antwort Letzte Antwort
        0
        • paul53P Offline
          paul53P Offline
          paul53
          schrieb am zuletzt editiert von
          #4

          @peoples:

          Und kann man den Befehlaufruf mitloggen `
          Versuche es mal mit Callback:

                  exec(([bash_script ,name, zeit, pfad].join('')), function(err, stdout, stderr) {
                    if(err) log(stderr, 'error');
                    else log('exec: ' + stdout);
                  });
          
          

          Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
          Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

          1 Antwort Letzte Antwort
          0
          • PeoplesP Offline
            PeoplesP Offline
            Peoples
            schrieb am zuletzt editiert von
            #5

            @paul53:

            Und kann man den Befehlaufruf mitloggen `
            Ja das geht

            Laut dem Log "Backup wird ausgeführt" sollte er das Script ausführen, zumindest bist zum "Backup erstell Befehl", denn die Rückmeldung dass etwas erstellt wurde fehlt:

            javascript.0	2017-12-23 07:15:40.766	info	--- Backup wird ausgefuehrt ---
            javascript.0	2017-12-23 07:15:40.766	info	script.js.Backup_Script: exec:
            javascript.0	2017-12-23 07:15:40.758	info	script.js.Backup_Script: registered 0 subscriptions and 0 schedules
            javascript.0	2017-12-23 07:15:40.738	info	Start javascript script.js.Backup_Script
            

            Wenn ich alles über Putty mache kommt nach der Erstellung noch folgendes:

            Backup created: /opt/iobroker/backups/2017_12_23-07_33_15_backupiobroker.tar.gz
            

            Hab das Shellscript mal auf:

            echo
            #Backup ausführen
            echo --- Backup wird ausgefuehrt ---
            ./iobroker backup
            echo
            
            

            gekürzt was aber auch nicht funktioniert.

            Das Backupscript ist ein Teil des von Knuddel verwendeten (http://forum.iobroker.net/viewtopic.php?f=21&t=9861) sollte somit auch funktionieren.

            Die einzigen Unterschiede sind, dass es bei mir nicht im Unterordner scripts/…. liegt sondern direkt im Iobroker Ordner deshalb spare ich mir den Verzeichnisswechsel und ich möchte es nicht via crontab machen weil ich hier keine Ahnung habe sondern über Javascript um das ganze später mal visualisieren zu können.

            Ich beantworte keine Fragen zu Themen via PN

            1 Antwort Letzte Antwort
            0
            • andreaskosA Offline
              andreaskosA Offline
              andreaskos
              schrieb am zuletzt editiert von
              #6

              Hat der von dir eingesetzte exec-Aufruf Vorteile gegenüber einem einfachen:

              exec("bash /opt/iobroker/backup.sh testname 10");
              
              

              ?

              1 Antwort Letzte Antwort
              0
              • PeoplesP Offline
                PeoplesP Offline
                Peoples
                schrieb am zuletzt editiert von
                #7

                @peoples:

                Hat der von dir eingesetzte exec-Aufruf Vorteile gegenüber einem einfachen: `

                Kann ich dir nicht sagen, da ich hier wirklich keine Anhung habe und mir das eben aus einem anderen Script einfach rauskopiert habe.

                Habe es eben auch mal mit deiner "Version" leider auch Erfolglos probiert.

                Gruß

                Steffen

                Ich beantworte keine Fragen zu Themen via PN

                1 Antwort Letzte Antwort
                0
                • PeoplesP Offline
                  PeoplesP Offline
                  Peoples
                  schrieb am zuletzt editiert von
                  #8

                  So habe es geschafft,

                  hier die kurze Erklärung: Der Aufruf der Backupfunktion mit "./iobroker backup" funktioniert nicht aus JavaScript herraus, wenn man aber "iobroker backup" aufruft gehts.

                  Gruß

                  Steffen

                  Ich beantworte keine Fragen zu Themen via PN

                  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

                  700

                  Online

                  32.5k

                  Benutzer

                  81.6k

                  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