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/