公司有几台linux服务器,时常需要查看日志;但是每个日志文件只有2m,日常查日志的时候很烦索;
由于服务器和程序已经很老了,没人敢去动他,所有想着写一个shell脚本,每当日志更新后便写入到一个总的log文件中
目录的结构:
-rw-r--r-- 1 root root 646809 5月 5 13:07 Server.log
-rw-r--r-- 1 root root 2049119 5月 5 12:22 Server.log1
-rw-r--r-- 1 root root 2048062 5月 5 10:01 Server.log2
-rw-r--r-- 1 root root 2048130 5月 5 06:58 Server.log3
-rw-r--r-- 1 root root 2048046 5月 5 02:01 Server.log4
-rw-r--r-- 1 root root 2048006 5月 4 18:21 Server.log5
-rw-r--r-- 1 root root 2048343 5月 4 14:59 Server.log6
-rw-r--r-- 1 root root 2048259 5月 4 12:06 Server.log7
-rw-r--r-- 1 root root 2048181 5月 4 08:24 Server.log8
日志会写入到Server.log中,当Server.log的大小等于2m时,Server.log会重命名为Server.log1,新的日志会继续写在Server.log中
思路是:获取Server.log1的最后修改时间,判断两个时间是否一致,如果不一致,就表示文件已更新,并将Server.log1的内容写入test.log文件中
新建uplog.sh文件
脚本如下:
#!/bin/bash
#写一个死循环
while true
do
#文件名
FILE_NAME='Server.log1'
#获取文件做后修改时间戳
LAST_one=`stat -c %Y $FILE_NAME`
#等待1~2秒后再获取一个时间
sleep 1s
LAST_two=`stat -c %Y $FILE_NAME`
# 这里可以格式化一下时间戳
# formart_date_one=`date '+%Y-%m-%d %H:%M:%S' -d @$LAST_one`
# formart_date_two=`date '+%Y-%m-%d %H:%M:%S' -d @$LAST_two`
# echo "one"$formart_date_one" two"$formart_date_two
#判断获取的时间是否相等
if test $[LAST_one] -ne $[LAST_two]
then
echo '!='
# 将Server.log1文件内容追加在test.log的末尾
cat Server.log1 >> test.log
echo "Server.log1 >> test.log"
fi
done
运行结果如下
[root@11222 log]# . uplog.sh
!=
ServerV5.log1 >> test.log
!=
ServerV5.log1 >> test.log