在实际Linux嵌入式项目开发中,应用程序的启动往往是通过在如/etc/init.d/rcS文件里添加需要运行的应用程序或脚本文件,从而实现自启动功能,正常情况能如期运行,但不完美的世界总就会有不完美的事情,凡事不能YY的过于美好,由于软件或硬件的一些隐藏bug干扰(作者自己在写这篇文章时还暂未定位到具体原因,后续若有进展会重新编辑该文章或在文章下以评论形式发布),这些设置自启动的应用程序或脚本并不能保证每次100%成功运行,所以才想到利用一监测脚本实现检查程序运行状态的功能(至于有的人会说你怎么能保证这个监测脚本每次就能保证100%成功运行呢,我只能回答,尽量发挥你的聪明才智,将此监测脚本添加到能靠近100%运行的地方去,从而满足最大的成功率)。
来点有用的
#!/bin/bash
# 应用程序绝对路径
APP_PATH=/home/root
# 应用程序名称
APP=TestApp
# 统计符合应用程序名称的总数
# 1.ps命令是罗列出当前运行的进程
# 2.-w是wide output(宽输出), 显示加宽可以显示较多的信息
# 3.有的会用-ef或-c来替代-w,如果你的运行环境支持-ef或-c那就用,看是否支持可以执行ps -h
# 4.-ef只匹配符合名称的进程,-c不匹配
# 5.grep -v "grep"去掉grep查询的那一条
# 6.wc -l结果统计数目
CNT=$(ps -w |grep $APP|grep -v "grep" |wc -l)
#对数目结果进行处理,注意前后的空格
if [ $CNT -eq 0 ]
then
echo "$APP not running"
# 如果需要重新启动,在这里重新运行
$APP_PATH/$APP
else
echo "$APP is running"
fi
如果需要一直检查,则需在脚本中加个while循环。