J'essaie de comprendre comment activer la journalisation des transmissions.
Je sais que je peux exécuter le démon à l'avant:
transmission-daemon -f --logfile /your/path/to/transmission.log
Mais ce n'est pas ce que je veux. Je souhaite activer cette option (logfile
) dans l'instance de service.
Jusqu'à présent, j'ai découvert que l'exécution de Sudo service transmission-daemon
exécute le fichier situé dans /etc/init.d/transmission-daemon
. Ce fichier (comme indiqué ci-dessous) ne me rend pas vraiment plus sage.
Jusqu'à présent, je comprends ce qui suit:
--exec $DAEMON -- $OPTIONS
exécute le démon effectif. Ce fichier (comme indiqué dans la variable en haut du script) se trouve dans /usr/bin/$NAME
. $NAME
est transmission-daemon
. C'est un exécutable situé là-bas.
Je pense donc que vous pouvez transmettre certaines options (par exemple, --logfile
). J'ai donc ajouté une instanciation de la variable OPTIONS
mais cela ne semble rien écrire.
J'ai essayé la ligne OPTIONS=" --logfile /smb/torrents/transmission.log"
afin de pouvoir les ajouter à l'exécution, mais une erreur est générée.
Une autre chose que j'ai essayée a été d'utiliser l'option sans guillemets.
OPTIONS= -e /smb/torrents/transmission.log
Cela me jette la même erreur:
: ~ $ Sudo service transmission-daemon restart /etc/init.d/transmission-daemon: 15: /etc/init.d/transmission-daemon: -e /smb/torrents/transmission.log: introuvable
Faire ce qui précède sans -
ne m’affiche aucune erreur, mais n’écrit pas non plus dans le fichier journal.
L'ajout de l'option --logfile
après l'exécution --exec $DAEMON --logfile /path/file -- $OPTIONS
génère également une autre erreur:
* Restarting bittorrent daemon transmission-daemon
start-stop-daemon: unrecognized option '--logfile'
Le fichier journal a des autorisations suffisantes, cependant:
-rwxrwxrwx 1 debian-transmission debian-transmission 0 Dec 30 11:14 transmission.log*
Donc ma question est, comment faire cela exactement?
#!/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
Je l'ai corrigé dans l'intervalle. Il existe également un fichier dans /etc/default/
nommé transmission-daemon
(voir ci-dessous). Ce fichier a une instanciation pour le paramètre OPTIONS
. Je viens d'ajouter --logfile /path/to/logfile
et cela a bien fonctionné!
# defaults for transmission-daemon
# sourced by /etc/init.d/transmission-daemon
# Change to 0 to disable daemon
ENABLE_DAEMON=1
# This directory stores some runtime information, like torrent files
# and links to the config file, which itself can be found in
# /etc/transmission-daemon/settings.json
CONFIG_DIR="/var/lib/transmission-daemon/info"
# Default options for daemon, see transmission-daemon(1) for more options
OPTIONS="--config-dir $CONFIG_DIR --logfile /path/transmission.log"
# (optional) extra options to start-stop-daemon
#START_STOP_OPTIONS="--iosched idle --nicelevel 10"