เปิดใช้งานการบันทึกไปยังบริการ


13

ฉันกำลังพยายามหาวิธีการเปิดใช้งานการเข้าสู่ระบบในการถ่ายโอน

ฉันรู้ว่าฉันสามารถเรียกใช้ภูตที่ด้านหน้า:

transmission-daemon -f --logfile /your/path/to/transmission.log

แต่นี่ไม่ใช่สิ่งที่ฉันต้องการ ฉันต้องการเปิดใช้งานตัวเลือกนี้ ( logfile) ในอินสแตนซ์ของบริการ

จนถึงตอนนี้ฉันได้ค้นพบว่าการเรียกใช้sudo service transmission-daemonงานไฟล์ที่อยู่ใน/etc/init.d/transmission-daemonนั้น ไฟล์นี้ (ดังที่แสดงด้านล่าง) ไม่ได้ทำให้ฉันฉลาดขึ้นจริงๆ

จนถึงตอนนี้ฉันเข้าใจสิ่งต่อไปนี้:

--exec $DAEMON -- $OPTIONS เรียกใช้ daemon ที่มีประสิทธิภาพ แฟ้มนี้ (เท่าที่เห็นในตัวแปรด้านบนของสคริปต์) /usr/bin/$NAMEตั้งอยู่ใน เป็น$NAME transmission-daemonนี่คือไฟล์ปฏิบัติการที่อยู่ในนั้น

ดังนั้นฉันคิดว่าคุณสามารถผ่านมันไปตามทางเลือกบางอย่าง (เช่น--logfile) ดังนั้นฉันจึงเพิ่มอินสแตนซ์ของOPTIONSตัวแปร แต่ดูเหมือนจะไม่เขียนอะไรเลย

ฉันลองใช้OPTIONS=" --logfile /smb/torrents/transmission.log"สายเพื่อให้ผนวกเข้ากับการดำเนินการ แต่มีข้อผิดพลาดเกิดขึ้น

อีกสิ่งหนึ่งที่ฉันพยายามคือใช้ตัวเลือกโดยไม่มีเครื่องหมายอัญประกาศ

OPTIONS= -e /smb/torrents/transmission.log

สิ่งนี้ทำให้ฉันมีข้อผิดพลาดเดียวกัน:

: ~ $ sudo service transmission-daemon รีสตาร์ท /etc/init.d/transmission-daemon: 15: /etc/init.d/transmission-daemon: -e /smb/torrents/transmission.log: ไม่พบ

การดำเนินการด้านบนโดย-ไม่แสดงข้อผิดพลาดใด ๆ ให้ฉัน แต่ไม่ได้เขียนลงในล็อกไฟล์เช่นกัน ..

การเพิ่ม--logfileตัวเลือกหลังจากการประมวล--exec $DAEMON --logfile /path/file -- $OPTIONSผลทำให้เกิดข้อผิดพลาดอื่นเช่นกัน:

* Restarting bittorrent daemon transmission-daemon
start-stop-daemon: unrecognized option '--logfile'

logfile มีสิทธิ์เพียงพอ แต่:

-rwxrwxrwx  1 debian-transmission debian-transmission    0 Dec 30 11:14 transmission.log*

ดังนั้นคำถามของฉันคือทำสิ่งนี้ได้อย่างไร

#!/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

คำตอบ:


16

ฉันแก้ไขมันในขณะเดียวกัน มีไฟล์ใน/etc/default/ชื่อtransmission-daemonด้วย (ดูด้านล่าง) ไฟล์นี้มีอินสแตนซ์สำหรับOPTIONSพารามิเตอร์ ฉันเพิ่งเพิ่ม--logfile /path/to/logfileและมันทำงานได้ดี!

# 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"
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.