6

我有一个在 Ubuntu 上运行的 SHOUTcast 服务器。服务器进程运行良好,但我似乎无法让守护程序脚本正常运行。在几个教程之后,我发现我想出了这个:

#!/bin/sh

CONFIG="/home/apps/shout32/sc_plex.conf"
DAEMON="/home/apps/shout32/sc_serv"

case "$1" in
    start)
        echo "Starting SC..."
        $DAEMON $CONFIG > /dev/null 2>&1 &
        ;;
    stop)
        echo "Stopping SC..."
        kill -9 `ps -C sc_serv -o pid --no-headers`
        ;;
    restart)
        echo "Rebooting SC..."
        kill -9 `ps -C sc_serv -o pid --no-headers`
        $DAEMON $CONFIG > /dev/null 2>&1 &
        ;;
    *)
        echo "usage: service sc32d {start | stop | restart}"
        exit 1
        ;;
esac

然而,这不起作用。我不知道这意味着什么,所以我开始逐行分解它。如果我删除 /dev/null 的东西——据我所知,这会使程序在后台“静默”运行——我收到这条消息,程序关闭:

root@streams3:/etc/init.d# service sc32d start
Starting SC...
root@streams3:/etc/init.d# 2013-05-21 14:41:50  E       msg:<***>       logger could not open file logs/sc_serv.log
2013-05-21 14:41:50     I       msg:<***>       Logger shutdown

root@streams3:/etc/init.d#
root@streams3:/etc/init.d# ps -C sc_serv
  PID TTY          TIME CMD
root@streams3:/etc/init.d#

我仍在研究 /dev/null 究竟做了什么以及为什么,所以我想手动运行这些命令和所有 /dev/null 的东西,我做了,这就是我得到某种错误代码的地方:

root@streams3:/etc/init.d# /home/apps/shout32/sc_serv /home/apps/shout32/sc_plex.conf > /dev/null 2>&1 &
[2] 2261
root@streams3:/etc/init.d#
[2]-  Exit 255                /home/apps/shout32/sc_serv /home/apps/shout32/sc_plex.conf > /dev/null 2>&1
root@streams3:/etc/init.d# ps -C sc_serv
  PID TTY          TIME CMD

不幸的是,从我所做的简短研究来看,“Exit 225”听起来像是一个包罗万象的错误代码,用于超出可接受的代码范围的代码。

整个问题的有趣部分是:当我导航到 /home/apps/shout32/ 文件夹并在那里运行命令时,没有完整路径......该死的东西有效:

root@streams3:/home/apps/shout32# ./sc_serv sc_plex.conf > /dev/null 2>&1 &
[2] 2245
root@streams3:/home/apps/shout32#
root@streams3:/home/apps/shout32# ps -C sc_serv
  PID TTY          TIME CMD
 2245 pts/0    00:00:00 sc_serv

那么,由于脚本文件位于 /etc/init.d/ 而不是应用程序所在的文件夹中,因此出现了问题?据我所知,我遵循已发布教程中的每一步,在 Ubuntu 中设置 SHOUTcast,然后制作守护进程......我认为我没有错过任何内容。我有一种感觉,解决方案要么是盯着我的脸,要么是某种模糊的权限,这有点让我头疼。

但任何帮助将不胜感激!


因此,根据下面的答案,我将 cd /home/apps/shout32/ 添加到脚本中的 START 命令中,还添加了 pwd 和 ls... 以查看是否可以消除脚本找不到 /日志/目录。

所以现在我的脚本是:

CONFIG="/home/apps/shout32/sc_plex.conf"
DAEMON="/home/apps/shout32/sc_serv"

cd /home/apps/shout32/

case "$1" in
        start)
                echo "Starting SC..."
                cd /home/apps/shout32/
                pwd
                ls
                $DAEMON $CONFIG &
                ;;
        stop)
                echo "Stopping SC..."
                kill -9 `ps -C sc_serv -o pid --no-headers`
                ;;
        restart)
                echo "Rebooting SC..."
                kill -9 `ps -C sc_serv -o pid --no-headers`
                $DAEMON $CONFIG &
                ;;
        *)
                echo "usage: service sc32d {start | stop | restart}"
                exit 1
                ;;
esac

我懂了:

admin@streams3:/etc/init.d$ service sc32d start
Starting SC...
/home/apps/shout32
changes.txt     readme.txt                     sc_serv_debug.conf
config_builder  sc_plex.conf                   sc_serv_public.conf
control         sc_serv                        sc_serv_relay.conf
docs            sc_serv2_linux_07_31_2011.tar  sc_serv_simple.conf
logs            sc_serv_basic.conf             tos.txt
admin@streams3:/etc/init.d$ 2013-06-05 17:52:08      E       msg:<***>      logger could not open file logs/sc_serv.log
2013-06-05 17:52:08     I       msg:<***>       Logger shutdown
4

1 回答 1

2

您的第二个片段包含logger could not open file logs/sc_serv.log. 所以它试图写入sc_serv.log它期望或想要在当前目录logs中它期望的目录中创建的文件。这也解释了当您首先 cd 到 /home/apps/shout32/ 时它可以工作。我猜有一个文件。/home/apps/shout32/logs/sc_serv.log

您可以配置该文件的位置吗?你不能cd ...在脚本的开头添加一些吗?

于 2013-06-03T21:53:48.063 回答