关于项目日志压缩和删除的操作
今天,遇到了问题,就是我们线上服务的日志打的比较多,前几天改过项目中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的操作(进行压缩包操作)