NEWS
Autostart Problem
-
Hi, vermutlich liegt der Fehler irgendwo in dem iobroker.sh….
Zeigt doch den Inhalt einmal unter etc/init.d/iobroker.sh
wichtig hierbei ist die Zeile NODECMD=
-
Hi,
@BuZZy Wenn ich systemctl status iobroker.service eingebe bekomme ich folgende Ausgabe:
root@raspberrypi:/home/pi# systemctl status iobroker.service ● iobroker.service - LSB: starts ioBroker Loaded: loaded (/etc/init.d/iobroker.sh) Active: failed (Result: exit-code) since Do 2017-11-16 10:37:52 CET; 1h 50min ago Process: 773 ExecStart=/etc/init.d/iobroker.sh start (code=exited, status=1/FA ILURE) Nov 16 10:37:52 raspberrypi systemd[1]: Starting LSB: starts ioBroker... Nov 16 10:37:52 raspberrypi iobroker.sh[773]: Starting ioBrokersudo: Uh, Sie…den Nov 16 10:37:52 raspberrypi systemd[1]: iobroker.service: control process ex...1 Nov 16 10:37:52 raspberrypi systemd[1]: Failed to start LSB: starts ioBroker. Nov 16 10:37:52 raspberrypi systemd[1]: Unit iobroker.service entered failed.... Hint: Some lines were ellipsized, use -l to show in full. root@raspberrypi:/home/pi#
Die Datei /etc/init.d/iobroker.sh sieht bei mir momentan so aus:
#!/bin/bash ### BEGIN INIT INFO # Provides: iobroker.sh # Required-Start: $network $local_fs $remote_fs # Required-Stop:: $network $local_fs $remote_fs # Default-Start: 2 3 4 5 # Default-Stop: 0 1 6 # Short-Description: starts ioBroker # Description: starts ioBroker ### END INIT INFO (( EUID )) && echo .You need to have root privileges.. && exit 1 PIDF=/opt/iobroker/node_modules/iobroker.js-controller/lib/iobroker.pid NODECMD=/usr/bin/node IOBROKERCMD=/opt/iobroker/node_modules/iobroker.js-controller/iobroker.js RETVAL=0 IOBROKERUSER=root start() { export IOBROKER_HOME=/opt/iobroker echo -n "Starting ioBroker" sudo -u ${IOBROKERUSER} $NODECMD $IOBROKERCMD start RETVAL=$? } stop() { echo -n "Stopping ioBroker" sudo -u ${IOBROKERUSER} $NODECMD $IOBROKERCMD stop RETVAL=$? } case "$1" in start) start ;; stop) stop ;; restart) stop start ;; *) echo "Usage: iobroker {start|stop|restart}" exit 1 ;; esac exit $RETVAL
Gruß
Dominik
-
Ändere
die Zeile
NODECMD=/usr/bin/node
in
NODECMD=/usr/local/bin/node
abspeichern und neustarten… und berichten.
-
Hi,
NODECMD=/usr/local/bin/node
Habe es zu diesem Pfad umbenannt, abgespeichert und neu gestartet, aber Iobroker startet leider immer noch nicht
-
Die Ausgabe von systemctl status iobroker.service wurde "beschnitten"..
Versuch nochmal````
systemctl status -l iobroker.service(das -l hinter "status" ist ein kleines L) Dann nochmal die Ausgabe posten. Der Eintrag NODECMD=/usr/bin/node ist schon korrekt.. (Auf meinem Raspberry 3 stimmt er zumindest). Gruß
-
Ich erhalte dann folgende Ausgabe
root@raspberrypi:/home/pi# systemctl status -l iobroker.service ● iobroker.service - LSB: starts ioBroker Loaded: loaded (/etc/init.d/iobroker.sh) Active: failed (Result: exit-code) since Do 2017-11-16 13:09:29 CET; 10min ago Process: 737 ExecStart=/etc/init.d/iobroker.sh start (code=exited, status=1/FAILURE) Nov 16 13:09:29 raspberrypi iobroker.sh[737]: Starting ioBrokersudo: Uh, Sie müssen ein TTY haben, um sudo zu verwenden Nov 16 13:09:29 raspberrypi systemd[1]: iobroker.service: control process exited, code=exited status=1 Nov 16 13:09:29 raspberrypi systemd[1]: Failed to start LSB: starts ioBroker.Nov 16 13:09:29 raspberrypi systemd[1]: Unit iobroker.service entered failed state. root@raspberrypi:/home/pi#
Gruß
Dominik
-
Da blockiert das System..
Siehe````
... Starting ioBrokersudo: Uh, Sie müssen ein TTY haben, um sudo zu verwendenWelches Betriebssystem verwendest du bzw. welche Version? Raspbian Jessie? Raspbian Stretch?
nano /etc/sudoers
Hast du da irgendwo sowas wie
Defaults requiretty
(Im "Nano Editor" scrollen mit den Pfeiltasten der Tastatur, beenden des Bearbeitungsmodus mit STRG+X) Gruß
-
Hi Buzzy,
Ich bin der Meinung dass auf meinem Raspberry momentan Raspian Jessie installiert ist.
Hab mir Mal die Datei sudoers angeschaut, da ist tatsächlich etwas mit requiretty.
GNU nano 2.2.6 Datei: /etc/sudoers # # This file MUST be edited with the 'visudo' command as root. # # Please consider adding local content in /etc/sudoers.d/ instead of # directly modifying this file. # # See the man page for details on how to write a sudoers file. # Defaults env_reset Defaults mail_badpass Defaults secure_path="/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/b$ # Host alias specification # User alias specification # Cmnd alias specification # User privilege specification root ALL=(ALL:ALL) ALL # Allow members of group sudo to execute any command %sudo ALL=(ALL:ALL) ALL # See sudoers(5) for more information on "#include" directives: #includedir /etc/sudoers.d #Für fhem damit dieses scripte im shell ausführen darf Defaults requiretty Defaults:%dialout !requiretty Defaults:fhem !requiretty fhem ALL=(ALL) NOPASSWD: ALL
Muss ich hier irgendwas anpassen?
Gruß
Dominik
-
Ja,
allerdings musst du jetzt zum Bearbeiten den Befehl````
visudoAlso:
visudo
Dann änderst du die vierte Zeile von unten: von```` Defaults requiretty ````in```` #Defaults requiretty ````- also ein # vorne dran hängen um den Eintrag auszukommentieren. Dann speicherst du mit STRG+X und drückst J bzw. Y auf der Tastatur um das Überschreiben zu bestätigen. (je nachdem ob du deutsche oder englische Sprache auf dem Raspberry eingestellt hast). Dann reboot und dann sollte es laufen. Die Datei sollte nach dem Bearbeiten also so bei dir aussehen:
GNU nano 2.2.6 Datei: /etc/sudoers
This file MUST be edited with the 'visudo' command as root.
Please consider adding local content in /etc/sudoers.d/ instead of
directly modifying this file.
See the man page for details on how to write a sudoers file.
Defaults env_reset
Defaults mail_badpass
Defaults secure_path="/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/b$Host alias specification
User alias specification
Cmnd alias specification
User privilege specification
root ALL=(ALL:ALL) ALL
Allow members of group sudo to execute any command
%sudo ALL=(ALL:ALL) ALL
See sudoers(5) for more information on "#include" directives:
#includedir /etc/sudoers.d
#Für fhem damit dieses scripte im shell ausführen darf
#Defaults requiretty
Defaults:%dialout !requiretty
Defaults:fhem !requiretty
fhem ALL=(ALL) NOPASSWD: ALLGruß
-
Und denk dran - diese Änderung die du vorhin vorgenommen hast rückgängig zu machen..
@knopers1:Ändere die Zeile
NODECMD=/usr/bin/node ````..in..```` NODECMD=/usr/local/bin/node ```` `
-
Ihr seid die besten.
Jetzt funktioniert der Autostart
Ich habe die Änderungen in /etc/init.d wieder Rückgängig gemacht in NODECMD=/usr/bin/node.
Das auskommentieren des Befehls````
#Defaults requirettyJetzt startet das Programm wieder bei jedem neustart. Besten Dank! Gruß Dominik
-
Siehe nächsten Eintrag:
-
Hi, ich habe mir den Beitrag nochmal in Ruhe durchgelesen und hatte das selbe Problem.
Da man aus FEHM heraus gerne auch Linux System Befehle ausführen möchte, fügt man gerne kn die Datei
nano /etc/sudoers
Die folgenden Zeilen ein:
Defaults requiretty Defaults:%dialout !requiretty Defaults:fhem !requiretty fhem ALL=(ALL) NOPASSWD: ALL
Wobei die Zeile
Defaults requiretty
Gift für den Autostart vom ioBrocker ist.
Somit muss diese auskommentiert oder gelöscht werden:
#Defaults requiretty
Wobei ich noch nicht die Aufgabe von der Zeile geprüft habe, denn in FHEM kann ich dennoch SSH Befehle ausführen.
Dennoch danke für den Beitrag hier.
-
Ich habe einen Pi2 mit Raspbian Stretch und bei mir startet der iobroker auch nicht automatisch.
der befehl
systemctl status -l iobroker.service
funktioniert nicht, da kommt folgendes
Unit iobroker.service could not be found.
habe dann
#Für fhem damit dieses scripte im shell ausführen darf #Defaults requiretty Defaults:%dialout !requiretty Defaults:fhem !requiretty fhem ALL=(ALL) NOPASSWD: ALL
in die
/etc/sudoers
eingefügt, brachte aber keinen erfolg
meine Datei /etc/init.d/iobroker.sh sieht auch etwas anders aus
#!/bin/bash ### BEGIN INIT INFO # Provides: iobroker.sh # Required-Start: $network $local_fs $remote_fs # Required-Stop:: $network $local_fs $remote_fs # Default-Start: 2 3 4 5 # Default-Stop: 0 1 6 # Short-Description: starts ioBroker # Description: starts ioBroker ### END INIT INFO (( EUID )) && echo .You need to have root privileges.. && exit 1 PIDF=/opt/iobroker/node_modules/iobroker.js-controller/lib/iobroker.pid NODECMD=@@node IOBROKERCMD=/opt/iobroker/node_modules/iobroker.js-controller/iobroker.js RETVAL=0 IOBROKERUSER=@@user start() { export IOBROKER_HOME=/opt/iobroker echo -n "Starting ioBroker" sudo -u ${IOBROKERUSER} $NODECMD $IOBROKERCMD start RETVAL=$? } stop() { echo -n "Stopping ioBroker" sudo -u ${IOBROKERUSER} $NODECMD $IOBROKERCMD stop RETVAL=$? } case "$1" in start) start ;; stop) stop ;; restart) stop start ;; *) echo "Usage: iobroker {start|stop|restart}" exit 1 ;; esac exit $RETVAL
Kann mir da einer weiterhelfen?
-
Wenn dein System noch frisch ist und du noch nichts weiter konfiguriert hast, würde ich die Speicherkarte mit Raspbian Jessie neu beschreiben und dann nochmal iobroker frisch installieren.
Image Raspbian Jessie Lite gibt's hier:
https://downloads.raspberrypi.org/raspb … e-lite.zip
Gruß
-
Weil auf Jessie läuft iobroker stabiler als auf Strech?
-
Hat bei mir mit Jessie sofort alles auf Anhieb geklappt und seit Installation nicht ein einziges mal Probleme gehabt.
Gruß
-
Die npm dateien sind aber heute geändert worden.
Müsste jetzt auch wieder mit stretch gehen.
Gruß Rainer
-
Die npm dateien sind aber heute geändert worden.
Müsste jetzt auch wieder mit stretch gehen.
Gruß Rainer `
und was muss ich dafür tun?
-
Neu drüber installieren
–-----------------------
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