2

我正在尝试在 /etc/init.d/ar_sendmail 中获取一个启动脚本(用于名为 ar_sendmail 的 ruby​​ gem):

#! /bin/sh

echo "in /etc/init.d/ar_sendmail"
DIR=/home/max/work/e_learning_resource/trunk
PATH=/var/lib/gems/1.8/bin
DAEMON=/var/lib/gems/1.8/bin/ar_sendmail
DAEMON_OPTS="-e production -d --batch-size 100 --delay 150"
NAME=ar_sendmail
DESC=ar_sendmail
PID_FILE=/home/max/work/e_learning_resource/trunk/shared/log/ar_sendmail.pid


test -x $DAEMON || exit 0
set -e

case "$1" in
  start)
        echo -n "Starting $DESC: "
        start-stop-daemon -d $DIR --start --quiet --pidfile $PID_FILE \
                --exec $DAEMON -- $DAEMON_OPTS
        echo "$NAME."
        ;;
  stop)
        echo -n "Stopping $DESC: "
        kill -TERM `cat $PID_FILE`        
    rm $PID_FILE
        echo "$NAME."
        ;;
  restart)
        echo -n "Restarting $DESC: "
        kill -TERM `cat $PID_FILE`        
    rm $PID_FILE
        sleep 1
        start-stop-daemon -d $DIR --start --quiet --pidfile \
                $PID_FILE --exec $DAEMON -- $DAEMON_OPTS
        echo "$NAME."
        ;;
      *)
            N=/etc/init.d/$NAME
            echo "Usage: $N {start|stop|restart|reload}" >&2
            exit 1   
            ;;
    esac

    exit 0

它在 start-stop-daemon 行上爆炸,说“start-stop-daemon: not found”。但是,当我手动将值插入该行并在命令行上运行它时,它可以工作。

我的第一个想法是这是shebang线,但#! /bin/sh应该是对的,不是吗?这绝对是正确的文件夹,也是我在其他 /etc/init.d 脚本中使用的文件夹。

我的第二个想法是它与 sudo 相关:我一直在非 sudo 中测试 start-stop-daemon 并在 sudo 模式下运行 /etc/init.d/ar_sendmail 。但是,我也可以使用 sudo 很好地运行 start-stop-daemon。

有点难过,有什么想法吗?

4

2 回答 2

2

正如@Dysaster 指出的那样,您正在PATH用这一行覆盖您的:

PATH=/var/lib/gems/1.8/bin

因为您正在为您的守护程序提供完整的路径名,所以我认为您可能甚至不需要添加/var/lib/gems/1.8/bin到您的路径中,除非ar_sendmail需要在不知道其路径的情况下执行该目录中的程序。(这肯定是不幸的,但很容易解决:PATH=/var/lib/gems/1.8/bin:$PATH.)

于 2011-03-08T10:37:50.420 回答
0

将 a 添加source /etc/profile到脚本的开头,以便您获得路径设置。

于 2011-03-08T10:23:47.467 回答