Ich versuche herauszufinden, wie die Anmeldung bei Transmission aktiviert wird.
Ich weiß, dass ich den Daemon im Vordergrund ausführen kann:
transmission-daemon -f --logfile /your/path/to/transmission.log
Aber das will ich nicht. Ich möchte diese Option ( logfile
) in der Dienstinstanz aktivieren .
Bisher habe ich festgestellt, dass beim Ausführen sudo service transmission-daemon
die Datei ausgeführt wird, die sich in befindet /etc/init.d/transmission-daemon
. Diese Datei (wie unten gezeigt) macht mich nicht wirklich weiser.
Soweit ich das folgende verstehe:
--exec $DAEMON -- $OPTIONS
Führt den effektiven Daemon aus. Diese Datei (wie in der Variablen oben im Skript zu sehen) befindet sich in /usr/bin/$NAME
. $NAME
ist transmission-daemon
. Dies ist eine ausführbare Datei, die sich dort befindet.
Ich denke, Sie können einige Optionen angeben (z. B. --logfile
). Also habe ich eine Instanziierung der OPTIONS
Variablen hinzugefügt , aber diese scheint nichts zu schreiben.
Ich habe die OPTIONS=" --logfile /smb/torrents/transmission.log"
Zeile ausprobiert , damit sie an die Ausführung angehängt wird, aber es wird ein Fehler ausgegeben.
Ich habe auch versucht, die Option ohne Anführungszeichen zu verwenden.
OPTIONS= -e /smb/torrents/transmission.log
Das wirft mir den gleichen Fehler:
: ~ $ sudo service transmission-daemon restart /etc/init.d/transmission-daemon: 15: /etc/init.d/transmission-daemon: -e /smb/torrents/transmission.log: nicht gefunden
Wenn Sie die obigen Schritte ohne -
ausführen, werden keine Fehler angezeigt, es wird jedoch auch kein Schreibzugriff auf die Protokolldatei ausgeführt.
Das Hinzufügen der --logfile
Option nach der Ausführung führt auch zu --exec $DAEMON --logfile /path/file -- $OPTIONS
einem anderen Fehler:
* Restarting bittorrent daemon transmission-daemon
start-stop-daemon: unrecognized option '--logfile'
Die Protokolldatei verfügt jedoch über ausreichende Berechtigungen:
-rwxrwxrwx 1 debian-transmission debian-transmission 0 Dec 30 11:14 transmission.log*
Meine Frage ist also, wie genau dies zu tun?
#!/bin/sh -e
### BEGIN INIT INFO
# Provides: transmission-daemon
# Required-Start: $local_fs $remote_fs $network
# Required-Stop: $local_fs $remote_fs $network
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: Start or stop the transmission-daemon.
### END INIT INFO
NAME=transmission-daemon
DAEMON=/usr/bin/$NAME
USER=debian-transmission
STOP_TIMEOUT=30
OPTIONS=" --logfile /smb/torrents/transmission.log"
export PATH="${PATH:+$PATH:}/sbin"
[ -x $DAEMON ] || exit 0
[ -e /etc/default/$NAME ] && . /etc/default/$NAME
. /lib/lsb/init-functions
start_daemon () {
if [ $ENABLE_DAEMON != 1 ]; then
log_progress_msg "(disabled, see /etc/default/${NAME})"
else
start-stop-daemon --start \
--chuid $USER \
$START_STOP_OPTIONS \
--exec $DAEMON -- $OPTIONS
fi
}
case "$1" in
start)
log_daemon_msg "Starting bittorrent daemon" "$NAME"
start_daemon
log_end_msg 0
;;
stop)
log_daemon_msg "Stopping bittorrent daemon" "$NAME"
start-stop-daemon --stop --quiet \
--exec $DAEMON --retry $STOP_TIMEOUT \
--oknodo
log_end_msg 0
;;
reload)
log_daemon_msg "Reloading bittorrent daemon" "$NAME"
start-stop-daemon --stop --quiet \
--exec $DAEMON \
--oknodo --signal 1
log_end_msg 0
;;
restart|force-reload)
log_daemon_msg "Restarting bittorrent daemon" "$NAME"
start-stop-daemon --stop --quiet \
--exec $DAEMON --retry $STOP_TIMEOUT \
--oknodo
start_daemon
log_end_msg 0
;;
status)
status_of_proc "$DAEMON" "$NAME" && exit 0 || exit $?
;;
*)
echo "Usage: /etc/init.d/$NAME {start|stop|reload|force-reload|restart|status}"
exit 2
;;
esac
exit 0