我正在使用Ubuntu 14.04 LTS,我想在启动时运行3个脚本。它们的名称如下:voe.sh
startUp.sh
和runDown.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
目录,其中保存了所有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 $
答案 0 :(得分:0)
我看到名称不匹配。 voe
内有/etc/init.d
,您尝试拨打voe.sh
。请检查名称
答案 1 :(得分:0)
了解一些细节:
执行runStart
runStart.sh
是两个不同的命令。在Windows中,不需要fileending .exe .com .bat等,在unix中你需要始终写出完整的文件名。
下一个问题,voe
执行runStart
和runStop
,换句话说,runStart
和runStop
不应该在/etc/rc.d
目录中和朋友们一样,只有voe
。将它们移动到已知的文件位置。例如/home/shankar/bin/runStart.sh
。然后,当您要执行这两个帮助程序时,您将需要使用完整路径,因为它们的路径不在$PATH
环境列表中(如果文件位于本地目录中,那么也是如此,那么在执行此cd /home/shanker/bin
之前,您需要先./runStart.sh
,以确保您位于正确的目录中,然后从那里执行。