Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. (gelöst )C-Programm auf Slave mit Rückgabewert ausführen

    NEWS

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    (gelöst )C-Programm auf Slave mit Rückgabewert ausführen

    This topic has been deleted. Only users with topic management privileges can see it.
    • Thomas Braun
      Thomas Braun Most Active @Ralf 6 last edited by

      @ralf-6 sagte in C-Programm auf Slave mit Rückgabewert ausführen:

      Command failed: /usr/local/bin/ ./drtr06

      Das ist falsch. Das muss als absoluter Pfad dann

      /usr/local/bin/drtr06
      lauten.

      1 Reply Last reply Reply Quote 0
      • paul53
        paul53 @Ralf 6 last edited by paul53

        @ralf-6 sagte: cmd: '/usr/local/bin/ ./drtr06'

        Das Kommando ist falsch. Ich nehme an, das Programm hat den Namen "drtr06"? Dann rufe es so auf, wenn es ausführbar unter /usr/local/bin liegt:

        const abfrage         = 'drtr06';
        
        R 1 Reply Last reply Reply Quote 0
        • R
          Ralf 6 @paul53 last edited by

          @paul53
          Das Javascript lautet jetzt:

          
          const abfrage         = 'drtr06';
          exec(abfrage, function(err, stdout, stderr) {
                  if (err) {
                      log(err,"error");
                      return;
                  }
                  console.warn('dein sensorwert ' + stdout);
           
          });
          
          

          Die Fehlermeldung dazu:

          28.10.2024, 17:52:57.159	[info ]: javascript.1 (740) Start JavaScript script.js.common.zum_Testen.drtr06_01 (Javascript/js)
          28.10.2024, 17:52:57.201	[info ]: javascript.1 (740) script.js.common.zum_Testen.drtr06_01: registered 0 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions
          28.10.2024, 17:52:57.214	[error]: javascript.1 (740) script.js.common.zum_Testen.drtr06_01: Error: Command failed: drtr06
          
              at genericNodeError (node:internal/errors:984:15)
              at wrappedFn (node:internal/errors:538:14)
              at ChildProcess.exithandler (node:child_process:422:12)
              at ChildProcess.emit (node:events:519:28)
              at ChildProcess.emit (node:domain:488:12)
              at maybeClose (node:internal/child_process:1105:16)
              at Socket.<anonymous> (node:internal/child_process:457:11)
              at Socket.emit (node:events:519:28)
              at Socket.emit (node:domain:488:12)
              at Pipe.<anonymous> (node:net:339:12) {
            code: 120,
            killed: false,
            signal: null,
            cmd: 'drtr06'
          }
          

          Und Ja, es liegt unter /usr/local/bin . Läßt sich mit drtr06 ansonsten von der Konsole ausführen

          paul53 1 Reply Last reply Reply Quote 0
          • paul53
            paul53 @Ralf 6 last edited by

            @ralf-6 sagte: Läßt sich mit drtr06 ansonsten von der Konsole ausführen

            Zeige bitte

            ls -l /usr/local/bin/drtr06
            
            R 1 Reply Last reply Reply Quote 0
            • R
              Ralf 6 @paul53 last edited by

              @paul53

              ralf@raspberrypi13:/ $ ls -l /usr/local/bin/drtr06
              -rwxr-xr-x 1 root root 70936 Oct 28 17:43 /usr/local/bin/drtr06
              ralf@raspberrypi13:/ $
              
              
              paul53 1 Reply Last reply Reply Quote 0
              • MartinP
                MartinP @Ralf 6 last edited by

                @ralf-6 Ich habe jetzt erst gesehen, dass Du schon ein Python-Script hast - wieso den Simple-Api-Aufruf aus meinem obigem Script nicht mit dem vorhandenen Python statt mit bash auslösen?

                Hängt natürlich ein wenig von den Skills in den verschiedenen Programmiersprachen ab - wenn Du Python besser beherrscht, als Javascript, wieso nicht dabei bleiben in diesem Fall?

                R 1 Reply Last reply Reply Quote 0
                • paul53
                  paul53 @Ralf 6 last edited by paul53

                  @ralf-6
                  Das Programm sollte so von jedem User ausführbar sein. Ich kann deshalb die Fehlermeldung aus dem Skript nicht interpretieren.

                  1 Reply Last reply Reply Quote 0
                  • R
                    Ralf 6 @MartinP last edited by

                    @martinp
                    Na ja, ich habe keine bis wenig Kenntnisse in Programmiersprachen. Das Python Skript ruft das C-Programm auf. Das wurde mir schon so eingerichtet. Und welche Optionen ich habe, um es in den IoBroker einzubinden, weiß ich nicht. Was ich schon hinbekommen habe, ich kann seit kurzem über das erweiterte Python Skript den Wert über MQTT in den IoBroker senden. Ist natürlich ein umständlicher Weg und ob es auf Dauer Stabil läuft muss ich erst Testen. Der Sensor ist ein Sensibelchen.

                    Thomas Braun MartinP 2 Replies Last reply Reply Quote 0
                    • Thomas Braun
                      Thomas Braun Most Active @Ralf 6 last edited by Thomas Braun

                      @ralf-6

                      Probier mal diese beiden Varianten im Terminal.

                      sudo -H -u iobroker drtr06
                      sudo -H -u iobroker /usr/local/bin/drtr06
                      

                      Und geh aus / heraus. Da hat der ralf nix verloren.
                      Geht per

                      cd
                      

                      (hoffentlich).

                      R 2 Replies Last reply Reply Quote 0
                      • R
                        Ralf 6 @Thomas Braun last edited by

                        @thomas-braun
                        Mir ist der Sensor gerade ausgestiegen und ich muss diesen neu Starten - das Dauert einen Moment. Ich werde es auf jeden Fall Testen und mich Melden
                        Danke

                        1 Reply Last reply Reply Quote 0
                        • MartinP
                          MartinP @Ralf 6 last edited by

                          @ralf-6 sagte in C-Programm auf Slave mit Rückgabewert ausführen:

                          Das wurde mir schon so eingerichtet.

                          Unter diesen Umständen ist es sicherlich besser, sich auf eine Programmiersprache zu konzentrieren. Bleib dann lieber bei Javascript, das gibt Dir wahrscheinlich mehr Nutzen, als sich zusätzlich noch in Python oder Shell-Programmierung einzufuchsen ...

                          1 Reply Last reply Reply Quote 0
                          • R
                            Ralf 6 @Thomas Braun last edited by

                            @thomas-braun
                            Mit folgendem Ergebnis:

                            • die erste Variante liefert das gewünschte Ergebnis, die zweite Variante bringt einen Fehler
                            ralf@raspberrypi13:~ $ sudo -H -u iobroker drtr06
                            Open /dev/i2c-1
                            Ok, now try access the device..
                            Received data: 4.58
                            ralf@raspberrypi13:~ $ sudo -H -u /usr/local/bin/drtr06
                            sudo: unknown user /usr/local/bin/drtr06
                            sudo: error initializing audit plugin sudoers_audit
                            
                            Thomas Braun 1 Reply Last reply Reply Quote 0
                            • Thomas Braun
                              Thomas Braun Most Active @Ralf 6 last edited by

                              @ralf-6

                              Mein Fehler. Das muss

                              sudo -H -u iobroker /usr/local/bin/drtr06
                              

                              lauten. Sollte dann aber eigentlich zum gleichen Ergebnis führen.

                              R 1 Reply Last reply Reply Quote 0
                              • R
                                Ralf 6 @Thomas Braun last edited by

                                @thomas-braun
                                Funktioniert auch

                                ralf@raspberrypi13:~ $ sudo -H -u iobroker /usr/local/bin/drtr06
                                Open /dev/i2c-1
                                Ok, now try access the device..
                                Received data: 4.58
                                
                                
                                1 Reply Last reply Reply Quote 0
                                • R
                                  Ralf 6 last edited by

                                  @arteck , @paul53 , @Thomas-Braun

                                  Hallo darf ich nochmals um Eure Unterstützung bitten.
                                  Die letzten Hinweise von @Thomas-Braun habe ich ausgeführt und eine Rückmeldung gegeben. Wenn ich den Befehl in mein Skript einbaue, bekomme ich folgende Fehlermeldung:

                                  30.10.2024, 10:06:28.698	[info ]: javascript.1 (749) Start JavaScript script.js.common.zum_Testen.drtr06_01 (Javascript/js)
                                  30.10.2024, 10:06:28.736	[info ]: javascript.1 (749) script.js.common.zum_Testen.drtr06_01: registered 0 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions
                                  30.10.2024, 10:06:28.786	[error]: javascript.1 (749) script.js.common.zum_Testen.drtr06_01: Error: Command failed: sudo -H -u iobroker /usr/local/bin/drtr06
                                  
                                      at genericNodeError (node:internal/errors:984:15)
                                      at wrappedFn (node:internal/errors:538:14)
                                      at ChildProcess.exithandler (node:child_process:422:12)
                                      at ChildProcess.emit (node:events:519:28)
                                      at ChildProcess.emit (node:domain:488:12)
                                      at maybeClose (node:internal/child_process:1105:16)
                                      at Socket.<anonymous> (node:internal/child_process:457:11)
                                      at Socket.emit (node:events:519:28)
                                      at Socket.emit (node:domain:488:12)
                                      at Pipe.<anonymous> (node:net:339:12) {
                                    code: 120,
                                    killed: false,
                                    signal: null,
                                    cmd: 'sudo -H -u iobroker /usr/local/bin/drtr06'
                                  }
                                  

                                  Dann habe ich folgendes ausprobiert:

                                  
                                  const abfrage         = 'sudo drtr06';
                                  exec(abfrage, function(err, stdout, stderr) {
                                          if (err) {
                                              log(err,"error");
                                              return;
                                          }
                                          console.warn('dein sensorwert ' + stdout);
                                   
                                  });
                                  
                                  

                                  Mit folgender Fehlermeldung:

                                  30.10.2024, 10:12:42.428	[info ]: javascript.1 (749) Start JavaScript script.js.common.zum_Testen.drtr06_01 (Javascript/js)
                                  30.10.2024, 10:12:42.467	[info ]: javascript.1 (749) script.js.common.zum_Testen.drtr06_01: registered 0 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions
                                  30.10.2024, 10:12:42.503	[error]: javascript.1 (749) script.js.common.zum_Testen.drtr06_01: Error: Command failed: sudo drtr06
                                  sudo: a terminal is required to read the password; either use the -S option to read from standard input or configure an askpass helper
                                  sudo: a password is required
                                  
                                      at genericNodeError (node:internal/errors:984:15)
                                      at wrappedFn (node:internal/errors:538:14)
                                      at ChildProcess.exithandler (node:child_process:422:12)
                                      at ChildProcess.emit (node:events:519:28)
                                      at ChildProcess.emit (node:domain:488:12)
                                      at maybeClose (node:internal/child_process:1105:16)
                                      at Socket.<anonymous> (node:internal/child_process:457:11)
                                      at Socket.emit (node:events:519:28)
                                      at Socket.emit (node:domain:488:12)
                                      at Pipe.<anonymous> (node:net:339:12) {
                                    code: 1,
                                    killed: false,
                                    signal: null,
                                    cmd: 'sudo drtr06'
                                  }
                                  

                                  Da ich etwas von " -S " gelesen habe. Ohne zu verstehen was dieses Bedeutet. Habe ich danach den Code wie folgt geändert:

                                  
                                  const abfrage         = 'sudo -S drtr06';
                                  exec(abfrage, function(err, stdout, stderr) {
                                          if (err) {
                                              log(err,"error");
                                              return;
                                          }
                                          console.warn('dein sensorwert ' + stdout);
                                   
                                  });
                                  
                                  

                                  Jetzt kam keine Fehlermeldung mehr:

                                  30.10.2024, 10:17:01.757	[info ]: javascript.1 (749) Start JavaScript script.js.common.zum_Testen.drtr06_01 (Javascript/js)
                                  30.10.2024, 10:17:01.798	[info ]: javascript.1 (749) script.js.common.zum_Testen.drtr06_01: registered 0 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions
                                  30.10.2024, 10:17:05.376	[info ]: javascript.1 (749) Stopping script script.js.common.zum_Testen.drtr06_01
                                  

                                  Was ich jetzt noch nicht sehe, ist eine Rückmeldung mit dem Sensorwert.
                                  Könnt Ihr mir bitte nochmals unter die Arme greifen.

                                  Danke für die Bemühungen

                                  Thomas Braun 1 Reply Last reply Reply Quote 0
                                  • Thomas Braun
                                    Thomas Braun Most Active @Ralf 6 last edited by

                                    @ralf-6

                                    NICHT mit sudo hantieren.

                                    R 1 Reply Last reply Reply Quote 0
                                    • R
                                      Ralf 6 @Thomas Braun last edited by

                                      @thomas-braun

                                      Ok, ohne sudo:

                                      
                                      const abfrage         = '-S drtr06';
                                      exec(abfrage, function(err, stdout, stderr) {
                                              if (err) {
                                                  log(err,"error");
                                                  return;
                                              }
                                              console.warn('dein sensorwert ' + stdout);
                                       
                                      });
                                      
                                      

                                      Ergebnis:

                                      30.10.2024, 10:36:34.019	[info ]: javascript.1 (749) Start JavaScript script.js.common.zum_Testen.drtr06_01 (Javascript/js)
                                      30.10.2024, 10:36:34.055	[info ]: javascript.1 (749) script.js.common.zum_Testen.drtr06_01: registered 0 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions
                                      30.10.2024, 10:36:34.068	[error]: javascript.1 (749) script.js.common.zum_Testen.drtr06_01: Error: Command failed: -S drtr06
                                      /bin/sh: 0: Illegal option -S
                                      
                                          at genericNodeError (node:internal/errors:984:15)
                                          at wrappedFn (node:internal/errors:538:14)
                                          at ChildProcess.exithandler (node:child_process:422:12)
                                          at ChildProcess.emit (node:events:519:28)
                                          at ChildProcess.emit (node:domain:488:12)
                                          at maybeClose (node:internal/child_process:1105:16)
                                          at Socket.<anonymous> (node:internal/child_process:457:11)
                                          at Socket.emit (node:events:519:28)
                                          at Socket.emit (node:domain:488:12)
                                          at Pipe.<anonymous> (node:net:339:12) {
                                        code: 2,
                                        killed: false,
                                        signal: null,
                                        cmd: '-S drtr06'
                                      }
                                      30.10.2024, 10:36:38.977	[info ]: javascript.1 (749) Stopping script script.js.common.zum_Testen.drtr06_01
                                      

                                      .

                                      Thomas Braun 1 Reply Last reply Reply Quote 0
                                      • Thomas Braun
                                        Thomas Braun Most Active @Ralf 6 last edited by

                                        @ralf-6

                                        -S auch weg. Eine Option kann nicht alleine stehen.

                                        R 2 Replies Last reply Reply Quote 0
                                        • R
                                          Ralf 6 @Thomas Braun last edited by

                                          @thomas-braun
                                          Ok, dann zurück auf Anfang:

                                          const abfrage         = 'drtr06';
                                          exec(abfrage, function(err, stdout, stderr) {
                                                  if (err) {
                                                      log(err,"error");
                                                      return;
                                                  }
                                                  console.warn('dein sensorwert ' + stdout);
                                           
                                          });
                                          

                                          Ergebnis:

                                          30.10.2024, 10:47:38.670	[info ]: javascript.1 (749) Start JavaScript script.js.common.zum_Testen.DRTR05 (Javascript/js)
                                          30.10.2024, 10:47:38.710	[info ]: javascript.1 (749) script.js.common.zum_Testen.DRTR05: registered 0 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions
                                          30.10.2024, 10:47:38.719	[error]: javascript.1 (749) script.js.common.zum_Testen.DRTR05: Error: Command failed: drtr06
                                          
                                              at genericNodeError (node:internal/errors:984:15)
                                              at wrappedFn (node:internal/errors:538:14)
                                              at ChildProcess.exithandler (node:child_process:422:12)
                                              at ChildProcess.emit (node:events:519:28)
                                              at ChildProcess.emit (node:domain:488:12)
                                              at maybeClose (node:internal/child_process:1105:16)
                                              at Socket.<anonymous> (node:internal/child_process:457:11)
                                              at Socket.emit (node:events:519:28)
                                              at Socket.emit (node:domain:488:12)
                                              at Pipe.<anonymous> (node:net:339:12) {
                                            code: 120,
                                            killed: false,
                                            signal: null,
                                            cmd: 'drtr06'
                                          }
                                          30.10.2024, 10:47:43.088	[info ]: javascript.1 (749) Stopping script script.js.common.zum_Testen.DRTR05
                                          
                                          1 Reply Last reply Reply Quote 0
                                          • R
                                            Ralf 6 @Thomas Braun last edited by

                                            @thomas-braun , @paul53 , @arteck

                                            Mit Blockly funktioniert es:

                                            2824d68a-9a2c-40c5-9b20-f06c2888cc3f-grafik.png

                                            Ergebnis:

                                            30.10.2024, 11:18:24.701	[info ]: javascript.1 (749) Start JavaScript script.js.common.zum_Testen.EXEC_Test02 (Blockly)
                                            30.10.2024, 11:18:24.738	[info ]: javascript.1 (749) script.js.common.zum_Testen.EXEC_Test02: registered 0 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions
                                            30.10.2024, 11:18:24.744	[info ]: javascript.1 (749) script.js.common.zum_Testen.EXEC_Test02: Open /dev/i2c-1
                                            Ok, now try access the device..
                                            Received data: 3.81
                                            
                                            30.10.2024, 11:18:27.322	[info ]: javascript.1 (749) Stopping script script.js.common.zum_Testen.EXEC_Test02
                                            
                                            <xml xmlns="https://developers.google.com/blockly/xml">
                                              <variables>
                                                <variable id="/16EE+_K=*X$-8wk05*~">result</variable>
                                              </variables>
                                              <block type="exec" id="6`{0RBpdd?)W9va2;7q}" x="138" y="88">
                                                <mutation xmlns="http://www.w3.org/1999/xhtml" with_statement="true"></mutation>
                                                <field name="WITH_STATEMENT">TRUE</field>
                                                <field name="LOG"></field>
                                                <value name="COMMAND">
                                                  <shadow type="text" id="J/jhzY*{+Z.!#]OZ%bWF">
                                                    <field name="TEXT">drtr06</field>
                                                  </shadow>
                                                </value>
                                                <statement name="STATEMENT">
                                                  <block type="debug" id="Ij0^mEEka!S?SVzrLy?g">
                                                    <field name="Severity">info</field>
                                                    <value name="TEXT">
                                                      <shadow type="text" id="@%w3)(Q`J;;p;ZqV+`pI">
                                                        <field name="TEXT">test</field>
                                                      </shadow>
                                                      <block type="variables_get" id="2k::W.@Vsr7nXn!6Uaql">
                                                        <field name="VAR" id="/16EE+_K=*X$-8wk05*~">result</field>
                                                      </block>
                                                    </value>
                                                  </block>
                                                </statement>
                                              </block>
                                            </xml>
                                            

                                            Da ich sowieso lieber mit Blockly arbeite, denke ich, wir lasssen das so.
                                            Oder spricht etwas dagegen?

                                            Jetzt muss ich nur noch schauen, wie ich den Wert extraiert bekomme. Habt Ihr dazu einen Vorschlag?

                                            Thomas Braun paul53 2 Replies Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            484
                                            Online

                                            31.7k
                                            Users

                                            79.8k
                                            Topics

                                            1.3m
                                            Posts

                                            5
                                            36
                                            1232
                                            Loading More Posts
                                            • Oldest to Newest
                                            • Newest to Oldest
                                            • Most Votes
                                            Reply
                                            • Reply as topic
                                            Log in to reply
                                            Community
                                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                            The ioBroker Community 2014-2023
                                            logo