当时需要不停查看不同的log以监控某些状态,这些log存在当天日期为名字的文件夹内,有5、6十个不同的log文件,每次需要敲键盘比较忙,故写了这个脚本。用户只要输入号码就可以实时跟踪查看相应的log文件,如果文件太多一时间不好找,可以输入关键词筛选文件。
TraceLogs()
{
today=`date --date='0 days ago' +%Y%m%d`
logpath="/home/xxxx/log/"$today #以当天日期命名的文件夹,保存着当前正在更新的log文件
pushd ./ #保存当前目录
#echo $logpath
cd $logpath #进入log文件夹
_bLoop=true
ls|sort|cat -n>/tmp/gatectrltmp.txt #获取所有log文件名 排序后加上行号存到一个文本文件中备用
while $_bLoop
do
cat /tmp/gatectrltmp.txt #在屏幕中列出所有的log文件名,带行号
echo -e " \033[45;39mInput a number from the list to trace a log (0 for quit), or input keywords to short the list :\033[0m" #提示用户输入行号(0:退出),或者关键词
read logInput #获取输入
jstr=`echo $logInput|sed -n '/^[0-9][0-9]*$/p'` #如果输入的是数字
if [ -n "$jstr" ]
then
if [ $logInput -eq 0 ] #=0 用户选择退出,
then
_bLoop=false
else
fname=$(grep -w "^ *$logInput" /tmp/gatectrltmp.txt |awk '{print $2}') #获取行号对应的文件名
echo You are searching logs includes: $logInput "file name: " $fname
tail -f $fname #实时跟踪查看log文件
_bLoop=false
fi
else #不是数字,是某些关键字,意味着用户希望筛选
echo You are searching logs includes: $logInput
ls |sort|grep -i $logInput|cat -n> /tmp/gatectrltmp.txt #筛选包含关键字的文件,再次存回文本文件,循环,则显示关键字筛选后的文件列表。
_bLoop=true
fi
done
popd
}
————————————
需要500关注,拜托点个关注,必定回关,谢谢!