关于日志文件的保存个数以及压缩和删除操作

关于项目日志压缩和删除的操作

今天,遇到了问题,就是我们线上服务的日志打的比较多,前几天改过项目中deploy/templates/cron.erb,不过不知道是由于什么原因,这个不生效,

原来也并不是很明白这个日志匹配规则,今天我们就来看一下这个日志的匹配规则,首先把我们的这个cron.erb里面的拿出来

01 * * * * work /usr/sbin/tmpwatch --nodirs -m 240 <%= scope["config::basedir"] %>/../../log/exchange-bid-service/

01 01 * * * root /usr/bin/find <%= scope["config::log_dir"] %> -type f -mtime +5  -name "*.gz" -delete

30 01 * * * root /usr/bin/find <%= scope["config::log_dir"] %> -type f -mtime +1   ! -name "*.gz" -exec gzip -f {} \;

首先我们先关心定时任务的两个,这个时候我们就需要linux底下的find的这个命令了

find命令用于:在一个目录(及子目录)中搜索文件,你可以指定一些匹配条件,如按文件名,文件类型,用户甚至是时间戳查找文件。

find [path...] [expression]

path:find命令查找的目录路径。例如用.表示当前目录,用/表示系统根目录

-type 超找某一类型的
b -块设备文件
d -目录
c -字符设备文件
p -管道文件

f -普通文件

-mtime 即modify time,指文件内容别修改的时间
find . -mtime中的参数n
find 。 -mtime n中的n指的是24*n, +n , -n n分别表示:
+n :大于n
-n :小于n

n  :等于n

find . -mtime n   最后一次修改发生在距离当前时间n*24小时至(n+1)*24小时
find . -mtime +n  最后一次修改发生在n+1天以前,距离当前时间为(n+1)*24小时至

find . -mtime -n  最后一次修改发生在n天以内,距离当前时间为n*24小时以内

-name 按照文件名称查找文件 
-exec,  find命令对匹配的文件执行该参数所给出的shell命令,相应命令的形式为'command' {} \;注意{}和\;之间的空格

find ./ size 0 -exec rm {} \;删除文件大小为0的文件

根据以上的对于find的命令的理解,我们可以对于以下语句做出以下的解释

01 01 * * * root /usr/bin/find <%= scope["config::log_dir"] %> -type f -mtime +5  -name "*.gz" -delete

每天的凌晨1点的1分钟,会找距离今天之前的(5+1)天的后缀名是.gz的文件执行delete操作

30 01 * * * root /usr/bin/find <%= scope["config::log_dir"] %> -type f -mtime +1   ! -name "*.gz" -exec gzip -f {} \;
每天的凌晨1点半,会找距离今天之前的(1+1)天额名字不是后缀是.gz结尾的文件进行gzip的操作(进行压缩包操作)


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值