一.日志文件
1.创建日志文件的重要性
统计排错
2.以时间为标志的日志文件
#!/bin/bash
#createlog
today=`date '+%Y-%m-$d'`
filelog="${today}.log
if [[ ! -e $filelog ]];then
touch $filelog
fi
echo "`date '+%Y-%m-%d %T'` log input start" >> $filelog
sleep 5
echo "`date '+%Y-%m-%d %T'` log input end" >> $filelog
echo "日志记录完毕"
3.以进程号为标志的日志文件
1).获取到所有httpd应用程序的进程号
2).把进程号存入一个临时文件中
3).从临时文件中取出所有的apache的进程号
4).使用for循环用kill杀掉所有的httpd进程
5).删除之前生成的临时文件
6).输出关闭进程后的消息
#!/bin/bash
tmpfile=$$.txt
ps -e|grep httpd|awk '{print $1}'
for pid in `cat $tmpfile`
do
echo 'apache ${pid} is killed!!!'
kill -9 $pid
done
sleep 1
rm -rf $tmpfile
echo 'apache已经被成功关闭!!!!'
二.logger生成系统日志
logger命令向 /var/log/message文件发送消息
格式:
logger -p -i message
1) -p:为优先级
2) -i:发送消息
三.信号类型
SIGHUP:挂起进程[1]
SIGING:来自键盘的中断ctrl+c[2]
SIGQUIT:从键盘退出ctrl+\[3]
SIGKILL:无条件终止[9]
四.trap信号捕捉
(一.)捕捉到一个信号后,它可能会采取下面三种操作之一:
1.不采取任何行动,由系统来处理
2.捕捉该信号,但忽略它
3.捕捉该信号,但采取相应的行动
(二)trap命令使用:
trap “function” signal
1).signal为接受到的信号
2).function为执行函数
常见行动:
1).清除临时文件
2).忽略该信号
3).询问用户是否终止脚本执行
#!/bin/bash
#signal
trap 'myfunc' 2
function myfunc(){
read -p '您确定终止该进程吗? yes or no: ' s
case $s in
'yes')
exit
;;
'no')
;;
*)
myfunc
;;
esac
}
i=0
while [[ ture ]]; do
let i++
echo $i
sleep 1
done