使用shell,将新增的log文件追加到一个新的文件中

公司有几台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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值