NEWS
(gelöst )C-Programm auf Slave mit Rückgabewert ausführen
-
@paul53 sagte in C-Programm auf Slave mit Rückgabewert ausführen:
... das kompilierte C-Programm in /home/iobroker.
Stimmt.
Ist der Pfad nicht auch ungünstig/falsch? Ich würde das immer mit vollem absoluten Pfad aufrufen und nicht mit
'/home/ralf/ ./drtr06'
Oder macht man das so in JS? -
@thomas-braun sagte: macht man das so in JS?
Nein, der Aufruf ist sicher falsch. An "exec" wird die normale Kommandozeile übergeben.
-
@thomas-braun
Ich habe keine Ahnung wo so ein Programm richtigerweise liegen sollte und wie ich es mit einem absoluten Pfad aufrufen kann.
Ich bin sonst nur im Blockly unterwegs und von Haus ein Mechaniker und mache dies zum ertsen Mal.
Bin jedoch lernwillig und gebe mir Mühe die Informationen in meine Mechanikersprache zu übersetzen.Vielen Dank für die Hilfe
-
Solche Programme gehören auch ganz eigentlich nach /usr/local/bin
Und da /usr/local/bin üblicherweise im $PATH liegt kannst du das dann auch direkt in der Kommandozeile aufrufen. Entsprechende Rechte natürlich vorausgesetzt. -
@thomas-braun
So das Programm liegt nun auf /usr/local/bin . Ich kann es auch aus der Konsole aufrufen und es gibt mir den Wert zurück.
Über das Script bekomme ich jedoch wieder eine Fehlermeldung.28.10.2024, 17:46:30.509 [info ]: javascript.1 (740) Start JavaScript script.js.common.zum_Testen.drtr06_01 (Javascript/js) 28.10.2024, 17:46:30.547 [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:46:30.558 [error]: javascript.1 (740) script.js.common.zum_Testen.drtr06_01: Error: Command failed: /usr/local/bin/ ./drtr06 /bin/sh: 1: /usr/local/bin/: Permission denied 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: 126, killed: false, signal: null, cmd: '/usr/local/bin/ ./drtr06' } 28.10.2024, 17:46:39.047 [info ]: javascript.1 (740) Stopping script script.js.common.zum_Testen.drtr06_01
Was ist der nächste Schritt?
-
@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. -
@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';
-
@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
-
@ralf-6 sagte: Läßt sich mit drtr06 ansonsten von der Konsole ausführen
Zeige bitte
ls -l /usr/local/bin/drtr06
-
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:/ $
-
@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?
-
@ralf-6
Das Programm sollte so von jedem User ausführbar sein. Ich kann deshalb die Fehlermeldung aus dem Skript nicht interpretieren. -
@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. -
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 percd
(hoffentlich).
-
@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 -
@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 ...
-
@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
-
Mein Fehler. Das muss
sudo -H -u iobroker /usr/local/bin/drtr06
lauten. Sollte dann aber eigentlich zum gleichen Ergebnis führen.
-
@thomas-braun
Funktioniert auchralf@raspberrypi13:~ $ sudo -H -u iobroker /usr/local/bin/drtr06 Open /dev/i2c-1 Ok, now try access the device.. Received data: 4.58
-
@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