Linux start-stop-daemon 目录错误调用 shell/python 脚本
Linux start-stop-daemon directory error calling shell/python script
我刚刚熟悉 Linux,由于目录问题,我似乎无法获得 start-stop-daemon
到 运行 的 python 脚本。在 linux 文件结构中,我有文件:
~/test.txt
THIS LINE IS A TEST
~/test.py
#!/usr/bin/python
import time
with open("test.txt") as f:
while True:
try:
print("Hello World")
print(f.readline())
time.sleep(2)
except KeyboardInterrupt:
f.close()
break
~/test.sh
#!/bin/bash
echo "SHELL SCRIPT SUCCESS" > /var/log/test.log
cd ~/
./test.py > /var/log/test.log
从任何目录调用 sudo bash ~/test.sh
后,test.log 会按预期填充来自 test.py 的标准输出。出于某种原因,启动以下 start-stop-daemon 服务脚本将生成 test.log 但不会使用标准输出填充它:
/etc/init.d/test
#!/bin/sh
### BEGIN INIT INFO
# Provides: Python test script
# Required-Start: $remote_fs $syslog
# Required-Stop: $remote_fs $syslog
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: Prints out daemonized argument
# Description: Creates output of argument
### END INIT INFO
DAEMON_DIR=/home/alex
DAEMON=$DAEMON_DIR/test.sh
DAEMON_NAME=test
DAEMON_OPTS="hello"
DAEMON_USER=root
PYTHON=/usr/bin/python
PIDFILE=/var/run/$DAEMON_NAME.pid
. /lib/lsb/init-functions
do_start () {
log_daemon_msg "Starting system $DAEMON_NAME daemon"
#start-stop-daemon --start --background --pidfile $PIDFILE --make-pidfile --user $DAEMON_USER --exec $PYTHON --startas $DAEMON
start-stop-daemon --start --background --pidfile $PIDFILE --make-pidfile --chuid $DAEMON_USER --startas /bin/bash /home/alex/test.sh
log_end_msg $?
}
do_stop () {
log_daemon_msg "Stopping system $DAEMON_NAME daemon"
start-stop-daemon --stop --pidfile $PIDFILE --retry 10
log_end_msg $?
}
case "" in
start|stop)
do_
;;
restart|reload|force-reload)
do_stop
do_start
;;
status)
status_of_proc "$DAEMON_NAME" "$DAEMON" && exit 0 || exit $?
;;
*)
echo "Usage: /etc/init.d/$DAEMON_NAME {start|stop|restart|status}"
exit 1
;;
esac
exit 0
这是可以在 start-stop-daemon
中解决的目录问题吗?
或者,我愿意接受其他可以通过冷启动持续存在的脚本服务方法(即没有 cron 作业)
尝试使用绝对路径调用 cd
,例如 /home/alexjg/
而不是 ~/
;它之前被破坏的原因是,在您的示例中,您使用的是 sudo
,它保留了用户的主目录 运行。但是,当您从 init 调用 bash 脚本时,它将使用不包含 test.py
.
的根目录
文件已创建,因为重定向仍然成功;但是因为启动 Python 失败所以没有输出。
我刚刚熟悉 Linux,由于目录问题,我似乎无法获得 start-stop-daemon
到 运行 的 python 脚本。在 linux 文件结构中,我有文件:
~/test.txt
THIS LINE IS A TEST
~/test.py
#!/usr/bin/python
import time
with open("test.txt") as f:
while True:
try:
print("Hello World")
print(f.readline())
time.sleep(2)
except KeyboardInterrupt:
f.close()
break
~/test.sh
#!/bin/bash
echo "SHELL SCRIPT SUCCESS" > /var/log/test.log
cd ~/
./test.py > /var/log/test.log
从任何目录调用 sudo bash ~/test.sh
后,test.log 会按预期填充来自 test.py 的标准输出。出于某种原因,启动以下 start-stop-daemon 服务脚本将生成 test.log 但不会使用标准输出填充它:
/etc/init.d/test
#!/bin/sh
### BEGIN INIT INFO
# Provides: Python test script
# Required-Start: $remote_fs $syslog
# Required-Stop: $remote_fs $syslog
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: Prints out daemonized argument
# Description: Creates output of argument
### END INIT INFO
DAEMON_DIR=/home/alex
DAEMON=$DAEMON_DIR/test.sh
DAEMON_NAME=test
DAEMON_OPTS="hello"
DAEMON_USER=root
PYTHON=/usr/bin/python
PIDFILE=/var/run/$DAEMON_NAME.pid
. /lib/lsb/init-functions
do_start () {
log_daemon_msg "Starting system $DAEMON_NAME daemon"
#start-stop-daemon --start --background --pidfile $PIDFILE --make-pidfile --user $DAEMON_USER --exec $PYTHON --startas $DAEMON
start-stop-daemon --start --background --pidfile $PIDFILE --make-pidfile --chuid $DAEMON_USER --startas /bin/bash /home/alex/test.sh
log_end_msg $?
}
do_stop () {
log_daemon_msg "Stopping system $DAEMON_NAME daemon"
start-stop-daemon --stop --pidfile $PIDFILE --retry 10
log_end_msg $?
}
case "" in
start|stop)
do_
;;
restart|reload|force-reload)
do_stop
do_start
;;
status)
status_of_proc "$DAEMON_NAME" "$DAEMON" && exit 0 || exit $?
;;
*)
echo "Usage: /etc/init.d/$DAEMON_NAME {start|stop|restart|status}"
exit 1
;;
esac
exit 0
这是可以在 start-stop-daemon
中解决的目录问题吗?
或者,我愿意接受其他可以通过冷启动持续存在的脚本服务方法(即没有 cron 作业)
尝试使用绝对路径调用 cd
,例如 /home/alexjg/
而不是 ~/
;它之前被破坏的原因是,在您的示例中,您使用的是 sudo
,它保留了用户的主目录 运行。但是,当您从 init 调用 bash 脚本时,它将使用不包含 test.py
.
文件已创建,因为重定向仍然成功;但是因为启动 Python 失败所以没有输出。