重启后,我使用 init.d 脚本从已挂载的网络共享 (autofs) 执行应用程序。脚本首先等待 30 秒,然后尝试执行命令,以等待网络/挂载点启动。
我想在执行命令之前以某种方式检测网络是否已真正启动并且挂载点是否已真正挂载。
您对如何使用这个脚本实现这一点(在 CentOS 6.4 中)有什么建议?
这就是我现在所拥有的:
#!/bin/bash
#
# chkconfig: 3 95 5
# description: My app
# processname: my-app
#
# Sleep for 30 seconds before attempting to execute command
sleep 30s
# Get function from functions library
. /etc/init.d/functions
# Start the service my-app from autofs mount
start() {
echo -n "Starting my-app: "
/share/path/my-app --log /tmp/log.log --supersede
### Create the lock file ###
touch /var/lock/subsys/my-app
success $"my-app startup"
echo
}
# Restart the service my-app
stop() {
echo -n "Stopping my-app: "
killproc my-app
### Now, delete the lock file ###
rm -f /var/lock/subsys/my-app
echo
}
### main logic ###
case "$1" in
start)
start
;;
stop)
stop
;;
status)
status my-app
;;
restart|reload|condrestart)
stop
start
;;
*)
echo $"Usage: $0 {start|stop|restart|reload|status}"
exit 1
esac
exit 0
答案1
init
脚本按 S## 编号定义的顺序启动。较新版本的 Unix(至少在 Linux 上)并行启动相同的 ## 编号(尽管您可以关闭该功能……)您所要做的就是在网络和fsmount
编号后面使用 ##。然后它应该可以工作。但是,如果fsmount
在后台启动,最简单的方法可能是探测已安装驱动器上的文件。类似这样的事情:
while ! test -f /mnt/over-there/this/file/here
do
sleep 1
done
这将等待文件出现。如果尚未出现,请休眠一秒钟然后重试。
为了避免有人在本地计算机上创建您正在测试的文件的潜在问题,您可能希望使用mountpoint
如下命令行:
while ! mountpoint -q /mnt/over-there
do
sleep 1
done
(来自下面的评论。)是-q
为了使命令安静。
---更新:30 次尝试后超时
在 shell 脚本中你还可以计数和测试数字:
count=0
while ! test -f /mnt/over-there/this/file/here
do
sleep 1
count=`expr $count + 1`
if test $count -eq 30
then
echo "timed out!"
exit 1
fi
done
如果计数达到 30(30 秒的休眠时间加上检查文件是否可用的时间)则停止,之后会打印错误消息“超时!”。
---更新:如果你要切换到 systemd
使用 systemd,单元部分支持:
ConditionPathIsMountPoint=/mnt/over-there
它的作用与上面的脚本相同,但没有超时。此语句会阻止启动命令,直到挂载存在为止。
答案2
因为目标目录可以存在但不能挂载,所以我更喜欢西蒙普在 /proc/mounts 上测试
if ! grep -qs '/the/mounted/dir' /proc/mounts; then