第十三节.Shell日志处理和信号捕捉

本文介绍了如何通过脚本创建并管理日志文件,包括按时间和进程号区分的日志记录方式,并探讨了如何利用logger命令生成系统日志。此外,还详细解释了不同类型的信号及其在脚本中的应用,包括如何通过trap命令捕捉信号并执行相应操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一.日志文件
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
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值