NEWS
Einen PI3 durch ioBroker herunterfahren?
-
Ich mußte ioBroker neu aufsetzten.
Jetzt bekomme ich diese Fehlermeldung in der LOG-Datei.
javascript.0 2020-08-07 15:08:47.189 error (24264) at Script.runInContext (vm.js:130:18) javascript.0 2020-08-07 15:08:47.189 error (24264) at script.js.common.PI3_CopyShop_PowerOff:2:7 javascript.0 2020-08-07 15:08:47.188 error (24264) TypeError: node_ssh is not a constructor javascript.0 2020-08-07 15:08:47.188 error (24264) ^ javascript.0 2020-08-07 15:08:47.188 error (24264) ssh = new node_ssh(); javascript.0 2020-08-07 15:08:47.188 error (24264) script.js.common.PI3_CopyShop_PowerOff: script.js.common.PI3_CopyShop_PowerOff:2
Was mache ich noch falsch?
Grüße
Manfred -
@Beowolf
Ist das Modul 'node-ssh' in die Konfiguration der Javascript-Instanz eingetragen ? -
So sieht das bei mir aus
Wenn ich das Skript unter iobroker "neustarte", kommt die Meldung im unteren LOG-Feld
16:22:20.233 info javascript.0 (24264) Stop script script.js.common.PI3_CopyShop_Neustart 16:22:20.297 info javascript.0 (24264) Start javascript script.js.common.PI3_CopyShop_Neustart 16:22:20.305 error javascript.0 (24264) script.js.common.PI3_CopyShop_Neustart: script.js.common.PI3_CopyShop_Neustart:2 16:22:20.306 error javascript.0 (24264) at script.js.common.PI3_CopyShop_Neustart:2:7
Ich habe zwei Skripte. Einmal für einen Neustart und einmal zum Ausschalten.
-
@Beowolf
Getestetconst node_ssh = require('node-ssh'); const ssh = new node_ssh();
und erhalte den gleichen Fehler:
javascript.1 2020-08-07 16:36:57.322 error (5051) at script.js.common.Test:13:13 javascript.1 2020-08-07 16:36:57.322 error (5051) TypeError: node_ssh is not a constructor javascript.1 2020-08-07 16:36:57.322 error (5051) ^ javascript.1 2020-08-07 16:36:57.322 error (5051) const ssh = new node_ssh(); javascript.1 2020-08-07 16:36:57.321 error (5051) script.js.common.Test: script.js.common.Test:13
-
-
@Beowolf bekomme den gleiche Fehler, aber erst seit dem letzten Javascript Adapter Update.
Im Script wird angezeigt, dass das Modul "node-ssh" nicht gefunden wird. -
Ist das den "rausgeflogen", oder nur ein Fehler?
-
@Beowolf gute Frage, weiß ich nicht. Mir ist es gestern nur aufgefallen, als ich meinen Po der am 3d Drucker hängt über iobroker runter fahren wollte. Ging bisher immer, vllt mal die Javascript Version downgraden, ob es dann funktioniert
-
-
@Thomas-Braun da kommt node-ssh@11.0.0
-
@coyote Genaue Rückmeldung?
-
Genaue Rückmeldung?
/opt/iobroker$ npm list node-ssh iobroker.inst@2.0.3 /opt/iobroker └─┬ iobroker.javascript@4.6.21 └── node-ssh@11.0.0
-
@coyote sagte:
Javascript Version downgraden, ob es dann funktioniert
Funktioniert auch mit Version 4.6.4 nicht. Muss wohl am Modul liegen.
-
Muss wohl am Modul liegen.
Der Zugriff wurde in Version 11.0.0 geändert:
const node_ssh = require('node-ssh').NodeSSH; const ssh = new node_ssh();
Die Doku unter npmjs.com ist noch nicht angepasst.
-
-
@Asgothian sagte in Einen PI3 durch ioBroker herunterfahren?:
Über ein Script geht das herunterfahren recht einfach:
node_ssh = require('node-ssh'); ssh = new node_ssh(); ssh.connect({ host: 'xxx.xxx.x.xxx', username: 'root', password: 'yourRootPasswordHere' }).then(() => { ssh.execCommand("YourShutdownCommandHere"); })
Mit einem anderen Command kann ich so den Plex-Dienst auf dem NAS stoppen/starten.
Was mich jedoch stört ist die Tatsache, dass ich mich für SSH als Administrator anmelden muss
und mein Passwort im Skript ersichtlich ist.Im Internet habe ich eine Seite gefunden, mit welchem man eine Key-Authentication erstellen kann.
Leider weis ich dennoch nicht, wie dies vonstatten gehen soll.
https://debian-administration.org/article/530/SSH_with_authentication_key_instead_of_passwordKann mir jemand helfen?
-
@Kusi Hilft dir dieser Thread vielleicht?
https://forum.iobroker.net/topic/12995/gelöst-blockly-per-ssh-an-anderen-rechner-und-script-ausführen -
@Kusi hilft dir das weiter
https://checkmk.de/lw_ssh_anmeldung_ohne_passwort.html -
@Kusi hast du dir mal den Adapter linux-control angesehen?
-
@Kusi Es gibt duzende Anleitungen - aber ich habe es ein 2.Mal geschafft und fahre gerade einen anderen PI mit iobroker - zwar mit Node-Red runter - aber es ist egal. Das sollte dann grundsätzlich funktionieren
Im Prinzip brauchst Du nur 2-3 Befehle und musst Dich als iobroker anmelden.
Ich gehe mal davon aus, Du hast auf beiden Raspberries einen User PI.
Mach mal Folgendes:
- Gib ein:
sudo -su iobroker cd ~
Dann solltest Du als Prompt das haben:
iobroker@<deineMaschine>:~ $
Wenn Du dann im iobroker HOME Verzeichnis
ls -la .ssh
eingibst solltest Du eigentlich eine Fehlermeldung haben - da dieses Verzeichnis nicht exisistiert.
Dann gibst ein:
ssh-keygen -t rsa -b 4096 -C "iobroker@<DeineMaschine>"
und bestätigst alles mit <Enter> ohne zusätzliches Passwort etc.
Zum Schluß kopierst Du alles auf Deine Zielmaschine indem Du Dich mit dem pi auf Deiner Zielmaschine dann anmeldest - alles bestätigen.
ssh-copy-id pi@<Zielmaschine>
Kommandos auf zum Runterfahren ist genauso dann nur dass Du den Zielpfad noch mitgibst.
Neustart der Zielmaschine sieht dann so aus:
ssh pi@<Zielmaschine> sudo reboot
Auf Deiner Zielmaschine hast Du dann unter dem HOME-Verzeichnis Deines pi Users auch ein Verzeichnis .ssh.
Wenn Du reinschaust hast Du eine Datei namens authorized_keys. Da findest Du die öffentlichen Schlüssel und kannst bei Bedarf auch wieder einzelne löschen!