У вас есть установка Chandler, которая работала нормально в течение нескольких месяцев, но недавно, когда я подключился к серверу, я заметил, что она не работает.
SSHing, подтвердил, что он не работает, поэтому я перехожу к ручному перезапуску через сценарий запуска моего chandler (/etc/init.d/chandler
), которая отлично работала месяцами и месяцами при различных перезагрузках и т. д., и я получаю следующую ошибку:
/chandler/bin/osafsrvctl: 24: Syntax error: "(" unexpected
Теперь, если я перейду прямо к /chandler/bin/osafsrvctl
запустите следующее как root /chandler/bin/osafsrvctl start
, запускается без ошибок.
Некоторый поиск в Интернете заставил меня поверить, что это как-то связано с тем, что Чендлеру нужен / bin / bash для правильного запуска, поскольку сценарий запуска - это Bash. Хорошо. Проверить /chandler/bin/osafsrvctl
файл, и он действительно использует /bin/bash
. Изменение сценария запуска init.d на использование / bin / bash ничего не дало, возникла та же ошибка. Здесь /etc/init.d/chandler
скрипт, генерирующий ошибку:
#!/bin/sh -e
### BEGIN INIT INFO
# Provides: chandler
# Required-Start: $local_fs $remote_fs $network $syslog
# Required-Stop: $local_fs $remote_fs $network $syslog
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: Start/stop chandler server
### END INIT INFO
#
# chandler This init.d script is used to start chandler.
# It basically just calls osafsrvctl.
# set environment variables
. /etc/default/chandler
# set local variables
RETVAL=$?
CHANDLER_HOME="/chandler"
# check input
case "$1" in
start)
if [ -f $CHANDLER_HOME/bin/osafsrvctl ];
then
/bin/su chandler $CHANDLER_HOME/bin/osafsrvctl start
fi
;;
stop)
if [ -f $CHANDLER_HOME/bin/osafsrvctl ];
then
/bin/su chandler $CHANDLER_HOME/bin/osafsrvctl stop
fi
;;
*)
echo "Usage: /etc/init.d/osafsrvctl {start|stop}"
exit 1
;;
esac
exit $RETVAL
Имейте в виду, что вышеперечисленное работало нормально до некоторого момента, когда они этого не делали - понятия не имею, что изменилось и почему это так, как сейчас.
Любые идеи?
Если этот сценарий работает с /bin/bash
убедитесь, что символическая ссылка /bin/sh
намекает на /bin/bash
а не другой снаряд (/bin/dash
например). У меня была аналогичная проблема с переносом сценария bash из старой системы Debian в новую.
Попробуйте изменить первую строку на #!/bin/bash -e
.