建立一个守护进程:
#! /bin/sh
PRO_NAME=./xxxx.sh
while true ; do
#用ps获取$PRO_NAME进程数量
echo ''> nohup.out
NUM=`ps aux | grep -w ${PRO_NAME} | grep -v grep |wc -l`
#echo $NUM
#少于1,重启进程
if [ "${NUM}" -lt "1" ];then
echo "${PRO_NAME} was killed"
${PRO_NAME} -d
#大于1,杀掉所有进程,重启
elif [ "${NUM}" -gt "1" ];then
echo "more than 1 ${PRO_NAME},killall ${PRO_NAME}"
killall -9 $PRO_NAME
${PRO_NAME} -d
fi
#kill僵尸进程
NUM_STAT=`ps aux | grep -w ${PRO_NAME} | grep T | grep -v grep | wc -l`
if [ "${NUM_STAT}" -gt "0" ];then
killall -9 ${PRO_NAME}
${PRO_NAME} -d
fi
sleep 5s
done
exit 0
建立一个重启DB的脚本(仅限rac使用),纯粹为方便:
#!/bin/bash
if [ $1 ]
then
{
db_name=$1
srvctl stop database -d $db_name -o abort
num=`ps -ef|grep -i smon_|grep -v grep|grep -v -i asm|awk '{print $2}' `
if [ ! $num ]
then
echo "database restart........."
fi
while [ "$num" ]
do
sleep 1
num=`ps -ef|grep -i smon_|grep -v grep|grep -v -i asm |awk '{ print $2 }'`
echo "database not shutdown ,please check!"
done
srvctl start database -d $1
num=`ps -ef|grep -i smon_|grep -v grep|grep -v -i asm |awk '{ print $2 } '`
if [ $num ]
then
echo "database starting "
fi
if [ ! -n "$num" ]
then
echo "start fail"
else
echo "start sucessfully"
fi
}
else
echo "No parameter ,eg: ./stop_db.sh dbname"
fi