gpt4 book ai didi

linux - 在启动和关闭时遇到运行 shell 脚本的错误

转载 作者:太空宇宙 更新时间:2023-11-04 12:52:24 26 4
gpt4 key购买 nike

我正在使用 Ubuntu 14.04 LTS,我想在启动时运行 3 个脚本。它们的命名如下:voe.sh startUp.shrunDown.sh

脚本 voe.sh 是主文件,它将依次调用其他 2 个文件,具体取决于系统是分别启动还是关闭。

我将所有 3 个文件复制到目录 /etc/init.d。然后我使用 sysv-rc-conf 实用程序将它们添加到适当的运行级别,如下所示:

shankar@shannkardell:~/Important Files$ sysv-rc-conf --list voe
voe 0:off 1:off 2:on 3:on 4:on 5:on 6:off
shankar@shannkardell:~/Important Files$ sysv-rc-conf --list startUp
startUp 0:off 1:off 2:on 3:on 4:on 5:on 6:off
shankar@shannkardell:~/Important Files$ sysv-rc-conf --list runDown
runDown 0:off 1:off 2:on 3:on 4:on 5:on 6:off

我检查了所有的 rc*.d 目录,它们都有指向 /etc/init.d 目录的正确符号链接(symbolic link),所有 3 个脚本都在该目录中保存。这些脚本的权限似乎也是正确的:

shankar@shannkardell:/etc/init.d$ ls -l voe startUp runDown
-rwxr-xr-x 1 root root 2781 Apr 20 14:58 runDown
-rwxr-xr-x 1 root root 2576 Apr 20 14:57 startUp
-rwxr-xr-x 1 root root 2242 Apr 20 14:57 voe

即便如此,当我重新启动我的机器时,我的boot.log 说:

/etc/init.d/rc: 121: /etc/init.d/rc: /etc/rc2.d/S20voe: not found

此外,我尝试通过如下运行从另一个目录(我还将其他 2 个保存在同一目录中)测试 voe.sh:

shankar@shannkardell:~/Important Files$ sudo bash voe.sh start
Starting GT.M for shankarNow using node v4.2.6 (npm v2.14.12)
-su: startUp.sh: command not found
*

我不是 Ubuntu 专家。因此,如果我能就此问题获得任何指导,那就太好了。

谢谢

编辑

以下是我关心的 3 个脚本的 ls -l:

shankar@shannkardell:/etc/init.d$ ls -l runDown voe startUp
-rwxr-xr-x 1 root root 2781 Apr 20 14:58 runDown
-rwxr-xr-x 1 root root 2242 Apr 20 14:57 voe
-rwxr-xr-x 1 root root 2576 Apr 20 14:57 startUp

shankar@shannkardell:/etc/rc0.d$ ls -l *runDown *startUp *voe
lrwxrwxrwx 1 root root 17 Apr 13 21:24 K80runDown -> ../init.d/runDown
lrwxrwxrwx 1 root root 17 Apr 13 21:24 K80startUp -> ../init.d/startUp
lrwxrwxrwx 1 root root 13 Apr 20 18:58 K80voe -> ../init.d/voe

shankar@shannkardell:/etc/rc1.d$ ls -l *runDown *startUp *voe
lrwxrwxrwx 1 root root 17 Apr 13 21:24 K80runDown -> ../init.d/runDown
lrwxrwxrwx 1 root root 17 Apr 13 21:24 K80startUp -> ../init.d/startUp
lrwxrwxrwx 1 root root 13 Apr 20 18:58 K80voe -> ../init.d/voe

shankar@shannkardell:/etc/rc2.d$ ls -l *runDown *startUp *voe
lrwxrwxrwx 1 root root 17 Apr 20 15:28 S20runDown -> ../init.d/runDown
lrwxrwxrwx 1 root root 17 Apr 20 15:28 S20startUp -> ../init.d/startUp
lrwxrwxrwx 1 root root 13 Apr 20 18:58 S20voe -> ../init.d/voe

shankar@shannkardell:/etc/rc3.d$ ls -l *runDown *startUp *voe
lrwxrwxrwx 1 root root 17 Apr 20 15:28 S20runDown -> ../init.d/runDown
lrwxrwxrwx 1 root root 17 Apr 20 15:28 S20startUp -> ../init.d/startUp
lrwxrwxrwx 1 root root 13 Apr 20 18:58 S20voe -> ../init.d/voe

shankar@shannkardell:/etc/rc4.d$ ls -l *runDown *startUp *voe
lrwxrwxrwx 1 root root 17 Apr 20 15:28 S20runDown -> ../init.d/runDown
lrwxrwxrwx 1 root root 17 Apr 20 15:28 S20startUp -> ../init.d/startUp
lrwxrwxrwx 1 root root 13 Apr 20 18:58 S20voe -> ../init.d/voe

shankar@shannkardell:/etc/rc5.d$ ls -l *runDown *startUp *voe
lrwxrwxrwx 1 root root 17 Apr 20 15:28 S20runDown -> ../init.d/runDown
lrwxrwxrwx 1 root root 17 Apr 20 15:28 S20startUp -> ../init.d/startUp
lrwxrwxrwx 1 root root 13 Apr 20 18:58 S20voe -> ../init.d/voe

shankar@shannkardell:/etc/rc6.d$ ls -l *runDown *startUp *voe
lrwxrwxrwx 1 root root 17 Apr 13 21:24 K80runDown -> ../init.d/runDown
lrwxrwxrwx 1 root root 17 Apr 13 21:24 K80startUp -> ../init.d/startUp
lrwxrwxrwx 1 root root 13 Apr 20 18:58 K80voe -> ../init.d/voe

voe.sh 脚本(位于/etc/init.d/voe):

#! /bin/bash
#
# $Source: /home/fwslc/lsb-fwslc/inst.bin/RCS/voe,v $
# $Revision: 20100820.1 $
#
# chkconfig: 2345 15 85
# description: GT.M System Startup and Shutdown scripts
#
### BEGIN INIT INFO
# Provides: wvehrvoe10
# Required-Start: $local_fs
# Required-Stop: $local_fs
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: Sequence Managers startup/rundown scripts
# Description: System Startup and Shutdown scripts
### END INIT INFO

# Author: K.S. Bhaskar <bhaskar@worldvista.org>
# Tweaked by Gus Landis <ldl@linux.com>
# Tweaked further by David Wicksell <dlw@linux.com>

# Do NOT "set -e"

# Source function library
bash -xv
source /lib/lsb/init-functions

NAME="`basename $0 | sed 's/...//'`"
PATH=/home/shankar/.nvm/versions/node/v4.2.6/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games
DESC="GT.M start/rundown scripts"
SCRIPTNAME=/etc/init.d/$NAME

#
# Function that starts WorldVistA EHR VOE/2.0oe
#
do_start() {
echo -n Starting GT.M for ${NAME}
echo `date` - Starting GT.M for ${NAME} >> /var/log/boot.log
su - ${NAME} -c /home/shankar/bin/startUp.sh
if [ $? == 0 ]; then
log_success_msg
echo GT.M for ${NAME} started successfully >> /var/log/boot.log
touch /var/lock/${NAME}
else
log_failure_msg
echo GT.M for ${NAME} did not start successfully >> /var/log/boot.log
fi
echo
}

#
# Function that stops WorldVistA EHR VOE/2.0oe
#
do_stop() {
echo -n Stopping GT.M for ${NAME}
echo `date` - Stopping GT.M for ${NAME} >> /var/log/boot.log
su - ${NAME} -c /home/shankar/runDown.sh
if [ $? == 0 ]; then
log_success_msg
rm /var/lock/${NAME}
echo GT.M for ${NAME} stopped successfully >> /var/log/boot.log
else
log_failure_msg
echo GT.M for ${NAME} did not stop successfully >> /var/log/boot.log
fi
echo
}

case "$1" in
start)
do_start
;;
stop)
do_stop
;;
restart|force-reload)
do_stop
do_start
;;
*)
echo "Usage: $SCRIPTNAME {start|stop|restart|force-reload}" >&2
echo "Not expected to run from /etc/init.d, but rather from /etc/rc?.d"
exit 3
;;
esac

# $RCSfile: voe,v $

startUp.sh 脚本(位于/home/shankar/bin/startUp.sh):

#! /bin/bash -l
#
# Package: FWSLC Infrastructure
# File: gtm_start.sh
# Summary: init script to start GT.M
# Maintainer: LD Landis & DL Wicksell
# Last Modified: Aug 20, 2010
#
# Written by LD Landis <ldl@linux.com>
# & DL Wicksell <dlw@linux.com>
# Copyright © 2010 Fourth Watch Software, LC
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU Affero General Public License (AGPL)
# as published by the Free Software Foundation, either version 3 of
# the License, or (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU Affero General Public License for more details.
#
# You should have received a copy of the GNU Affero General Public License
# along with this program. If not, see http://www.gnu.org/licenses/.
#
# $Source: /home/fwslc/lsb-fwslc/inst.bin/RCS/gtm_start.sh,v $
# $Revision: 20100820.1 $
#
# Ensures that GT.M is recovered and starts new journal
bash -xv
cd /home/shankar
source /home/shankar/EHR/env2

LOGDIR=/home/shankar/log/`basename $0 .sh`
LOG=${LOGDIR}/`date +"%Y%m%d%H%M"`

if [ ! -d ${LOGDIR} ] ; then
mkdir -p ${LOGDIR}
fi

if [ ! -r /home/shankar/EHR/g/mumps.mjl ] ; then
echo "No database to start in `pwd`" > ${LOG}
exit 1
fi

echo "**Recover Journals**" >> ${LOG}
mupip journal -recover -backward /home/shankar/EHR/g/mumps.mjl >> ${LOG} 2>&1
#mupip journal -recover -backward ~/EHR/j/ewdgbl.mjl >> ${LOG} 2>&1
echo "**Enable Journals**" >> ${LOG}
mupip set -journal="enable,on,before" -file /home/shankar/EHR/g/mumps.dat >> ${LOG} 2>&1
#mupip set -journal="enable,on,before" -file ~/EHR/g/ewdgbl.dat >> ${LOG} 2>&1
echo "**Rundown database**" >> ${LOG}
mupip rundown -reg "*" >> ${LOG} 2>&1
if [ "${REPL_SIDE}" == "PRIMARY" ] ; then
echo "**Starting Taskman**" >> ${LOG}
echo y | mumps -run START^ZTMB >> ${LOG} 2>&1
if [ $? == 0 ] ; then
echo "###Successfully finished###" >> ${LOG}
else
echo "###Did not run successfully###" >> ${LOG}
fi
fi

exit 0

# $RCSfile: gtm_start.sh,v $

runDown.sh 脚本(位于/home/shankar/bin/runDown.sh):

#! /bin/bash -l
#
# Package: FWSLC Infrastructure
# File: gtm_rundown.sh
# Summary: init script to stop GT.M
# Maintainer: LD Landis & DL Wicksell
# Last Modified: Jan 24, 2012
#
# Written by LD Landis <ldl@linux.com>
# & DL Wicksell <dlw@linux.com>
# Copyright © 2010-2012 Fourth Watch Software, LC
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU Affero General Public License (AGPL)
# as published by the Free Software Foundation, either version 3 of
# the License, or (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU Affero General Public License for more details.
#
# You should have received a copy of the GNU Affero General Public License
# along with this program. If not, see http://www.gnu.org/licenses/.
#
# $Source: /home/fwslc/lsb-fwslc/inst.bin/RCS/gtm_rundown,sh,v $
# $Revision: 20121217.1 $
#
# Stop GT.M
bash -xv
cd /home/shankar
source /home/shankar/EHR/env2

LOGDIR=/home/shankar/log/`basename $0 .sh`
LOG=${LOGDIR}/`date +"%Y%m%d%H%M"`

if [ ! -d ${LOGDIR} ] ; then
mkdir -p ${LOGDIR}
fi

if [ ! -r /home/shankar/EHR/g/mumps.dat ] ; then
echo "No db to rundown in `pwd`" > ${LOG}
exit 1
fi

if [ "${REPL_SIDE}" == "PRIMARY" ] ; then
(
mumps -direct << EOF
s U="^"
d STOP^ZTMKU
y
y
y
h
EOF
) >> ${LOG} 2>&1

TEST="true" STIME=`date '+%s'`
while ${TEST}
do
gtm_prompt="" TEST=`mumps -direct <<< 'w $d(^%ZTSCH("RUN"))#2'`

if [ ${TEST} -eq 1 ] ; then
TEST="true"
elif [ ${TEST} -eq 0 ] ; then
TEST="false"
else
echo "`basename $0` may have a bug in it" >> ${LOG} 2>&1
fi

NOW=`date '+%s'`

if [ `expr ${NOW} - ${STIME}` -ge 30 ] ; then
TEST="false"

echo "TaskMan took too long to shut down, force quit" >> ${LOG} 2>&1
echo
fi
done
fi

CMD="pgrep -u ${USER} mumps"

PROCS=`eval ${CMD}`
if [ ! -z "${PROCS}" ] ; then
for i in `echo ${PROCS}`
do
mupip stop ${i} >> ${LOG} 2>&1
done
fi

sleep 1

PROCS=`eval ${CMD}`
if [ ! -z "${PROCS}" ] ; then
pkill -9 mumps >> ${LOG} 2>&1
fi

sleep 1

mupip rundown -region "*" >> ${LOG} 2>&1

exit 0

# $RCSfile: gtm_rundown.sh,v $

最佳答案

我看到名称不匹配。 /etc/init.d 中有voe,您尝试调用voe.sh。请检查名称

关于linux - 在启动和关闭时遇到运行 shell 脚本的错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36775613/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com