修改python守护程序脚本,停止

2024-03-29 11:42:42 发布

您现在位置:Python中文网/ 问答频道 /正文

我正在尝试使用来自here的一些输入来修改这个example,因为我只想停止作为守护进程运行的特定Python应用程序,因为在Python上运行的同一服务器上也会有其他应用程序,所以不想杀死所有Python脚本。。。你知道吗

服务器运行的是Amazon Linux,我相信是CentOS。你知道吗

USER="root"
APPNAME="myPythonApp1"
APPBIN="/usr/bin/python"
APPARGS="/usr/local/sbin/app1/app.py"
LOGFILE="/var/log/$APPNAME/error.log"
LOCKFILE="/var/lock/subsys/$APPNAME"

LOGPATH=$(dirname $LOGFILE)

prog=$APPBIN

start() {
        [ -x $prog ] || exit 5
        [ -d $LOGPATH ] || mkdir $LOGPATH
        [ -f $LOGFILE ] || touch $LOGFILE

        echo -n $"Starting $APPNAME: "
        daemon --user=$USER "$APPBIN $APPARGS >>$LOGFILE &"
        RETVAL=$?
        echo
        [ $RETVAL -eq 0 ] && touch $LOCKFILE
        return $RETVAL
}

stop() {
        echo -n $"Stopping $APPNAME: "
        pid=`ps -ef | grep '[p]ython $APPARGS' | awk '{ print $2 }'`
        echo $pid
        kill $pid
        sleep 1
        RETVAL=$?
        echo
        [ $RETVAL -eq 0 ] && rm -f $LOCKFILE
        return $RETVAL
}

开始很好,没问题。当我尝试停止时,我得到一个错误:

kill: usage: kill [-s sigspec | -n signum | -sigspec] pid | jobspec ... or kill -l [sigspec]

如果我从shell运行命令来获取pid,它会工作:

ps -ef | grep '[p]ython /usr/local/sbin/app1/app.py' | awk '{ print $2 }'

我得到了进程ID,那么我遗漏了什么。。。?你知道吗

非常感谢!你知道吗


Tags: echo服务器应用程序进程usrpidkilllogfile
1条回答
网友
1楼 · 发布于 2024-03-29 11:42:42

在grep表达式中使用单引号:

grep '[p]ython $APPARGS'

在单引号中,变量不会展开。应使用双引号:

grep "[p]ython $APPARGS"

相关问题 更多 >