UMS.sh (запускается как служба) в Ubuntu 14.04 не читает файл конфигурации

Я пытаюсь заставить свой Ubuntu 14.04 работать на универсальном медиа-сервере, чтобы я мог транслировать фильмы на мою PS3 (самая низкая прошивка 4.55, к сожалению, не может быть взломана).

После долгих исследований в сети я смог запустить его как сервис, /etc/init.d/UMS.shостальные файлы находятся в /usr/ums папка. К ним относятся UMS.conf конфигурационный файл, UMS.sh файл и ums.jar файл и все остальные.

Я использовал cream (gedit есть проблемы с созданием этих временных файлов, которые мне нужно удалить позже) для редактирования UMS.conf файл.

Я пытаюсь заставить его работать на определенном порту и иметь белый список IP-адресов, чтобы все в сети не могли получить доступ к моим материалам.

Так что я внес изменения на UMS.conf файл, загрузил его несколько раз, чтобы дважды проверить, что изменения сохранены - они сделали - но когда я делаю:

   service UMS.sh start

UMS запустится, но со всеми настройками по умолчанию.

Пожалуйста помоги. Я новичок в Ubuntu, поэтому, пожалуйста, проведите меня. Я могу предоставить сценарий /etc/init.d/UMS.sh если это поможет, но, пожалуйста, скажите мне, как вставить здесь, я попробовал и # сделал жирный шрифт.

ОБНОВЛЕНИЕ: С помощью комментария Летиции, вот сценарий для

'/Etc/init.d/UMS.sh'

#!/bin/bash
#
### BEGIN INIT INFO
# Provides:          ums
# 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: Starts UMS program.
# Description:       Java Upnp Media Server dedicated to PS3
### END INIT INFO

#set -x

# Author: Papa Issa DIAKHATE <paissad@gmail.com>
#
PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin
DESC="Universal Media Server"
NAME=UMS.sh
UMS_PROFILE=/etc/$NAME
DAEMON=/usr/ums/$NAME
DAEMON_OPTS="console"
SCRIPTNAME=/etc/init.d/$NAME
UMS_START=1 # Wether to start or not UMS ver at boot time.
DODTIME=30  # Time to wait for the server to die, in seconds.
            # If this value is set too low you might not
            # let the program to die gracefully and 'restart' will not work

test -x $DAEMON || exit 1

# Load the VERBOSE setting and other rcS variables
. /lib/init/vars.sh

# Define LSB log_* functions.
# Depend on lsb-base (>= 3.0-6) to ensure that this file is present.
. /lib/lsb/init-functions

# Include ums defaults if available
if [[ -f "/etc/default/$NAME" ]] ; then
        . /etc/default/$NAME
fi

# May we run the init.d script ?
[[ $UMS_START = 1 ]] || exit 1

#--------------------------------------------------------------------------
# Some color codes
txtred=$'\e[0;31m' # Red
txtylw=$'\e[0;33m' # Yellow
txtrst=$'\e[0m'    # Text Reset
#--------------------------------------------------------------------------
warnout(){
    echo >&2 -e ""$txtylw"Warning:$txtrst $1"
}
#--------------------------------------------------------------------------
running(){
    pid=`pgrep -f 'java .*ums.jar.*'`
}
#--------------------------------------------------------------------------
do_start(){
    running && { warnout "$NAME is already running !"; exit 0; }
    echo "Starting $DESC : $NAME"
    UMS_PROFILE="$UMS_PROFILE" start-stop-daemon --start --quiet --background --oknodo \
        --exec $DAEMON -- $DAEMON_OPTS

}
#--------------------------------------------------------------------------
do_stop(){
    running || { warnout "$NAME is NOT running !"; exit 0; }   
    local countdown="$DODTIME"
    echo -e "Stopping $DESC : $NAME \c "
    kill -9 $pid
    while running; do
        if (($countdown >= 0)); then
            sleep 1; echo -n .;
            ((--countdown))
        else
            break;
        fi
    done
    echo
    # If still running, then try to send SIGINT signal
    running && { \
        echo >&2 "Using kill -s SIGINT instead"; \
        echo >&2 "If you see this message again, then you should increase the value of DODTIME in '$0'."; \
        kill -2 $pid; \
    }

    if [ -e "/usr/share/ums/debug.log" ]; then
    count=9
    while [ $count -ge 1 ]
    do
    if [ -e "/usr/share/ums/debug.log.$count" ]; then
        plus=$((count+1))
        mv "/usr/share/ums/debug.log.$count" "/usr/share/ums/debug.log.$plus"
    fi
        count=$((count-1))
    done
    if [ -e "/usr/share/ums/debug.log" ]; then
        mv "/usr/share/ums/debug.log" "/usr/share/ums/debug.log.1"
    fi
    fi

    return 0
}
#--------------------------------------------------------------------------
do_force-stop(){
    running || { warnout "$NAME is NOT running !"; exit 0; }   
    echo "Stopping $DESC : $NAME"
    kill -9 $pid
    if [ -e "/usr/share/ums/debug.log" ]; then
    count=9
    while [ $count -ge 1 ]
    do
    if [ -e "/usr/share/ums/debug.log.$count" ]; then
        plus=$((count+1))
   mv "/usr/share/ums/debug.log.$count" "/usr/share/ums/debug.log.$plus"
    fi
       count=$((count-1))
    done
    if [ -e "/usr/share/ums/debug.log" ]; then
   mv "/usr/share/ums/debug.log" "/usr/share/ums/debug.log.1"
    fi
    fi
}
#--------------------------------------------------------------------------
do_status(){
    echo -n " * $NAME is "
    ( running || { echo "NOT running "; exit 0; } )
    ( running && { echo "running (PID -> $(echo $pid))"; exit 0; } )
}
#--------------------------------------------------------------------------
case "$1" in

    start|stop|force-stop|status)
        do_${1}
        ;;
    restart|reload)
        do_stop
        do_start
        ;;
    force-restart|force-reload)
        do_force-stop
        do_start
        ;;
    *)
        echo "Usage: $SCRIPTNAME {start|stop|force-stop|restart|force-restart|reload|force-reload|status}"
        exit 1
        ;;
esac

2 ответа

Похоже, вы использовали тот же скрипт, который я сделал для установки UMS. Я столкнулся с этой же проблемой и нашел способ ее исправить. Сценарий создает ссылку в / etc, которая указывает на файл в / root, который не существует. Если вы выполните ls -l в / etc, вы должны увидеть что-то вроде:

UMS.sh < /root/.config/UMS.conf

но скрипт никогда не создает этот файл, вероятно, тоже не имеет прав доступа. Поэтому я удалил эту ссылку и создал новую, указывающую на файл конфигурации в / usr / ums /

sudo rm /etc/UMS.sh
sudo ln -s /usr/ums/UMS.conf /etc/UMS.sh

Это сработало для меня, и теперь я могу просто отредактировать файл UMS.conf, чтобы внести любые изменения. Надеюсь это поможет.

Нет, правильное решение:

  • запустите UMS.sh от имени пользователя root; это создаст профиль /root/.config/UMS
  • отредактируйте скрипт инициализации /etc/init.d/ums и укажите правильный путь к профилю: UMS_PROFILE=/root/.config/UMS/
Другие вопросы по тегам