Linux——定时清空日志内容和删除日志文件

Stella981
• 阅读 1182

前言

最近在做性能压测试,会生成大量的日志,导致后续越压越慢,最终磁盘空间占满之类的问题。老是要手动删除日志文件,为避免此类问题发生,编写一个Linux日志定时清理的脚本,一劳永逸。

1、shell脚本

  • 创建脚本并赋权

    touch /home/mppay/auto-truncate-log.shchmod u+x auto-truncate-log.sh

  • 编辑脚本

    vi auto-truncate-log.sh

【清空日志文件内容】脚本如下:

#!/bin/sh
#可填写多个路径
workdir=("/home/mppay/apache-tomcat-7.0.73/logs" "/home/mppay/logs")
for wdir in ${workdir[@]}; do
  echo -e "filepath is ${wdir}"
  # .log 文件和包含 log 标记的 .txt文件,以及 catalina.out 文件
  find $wdir -regex "^.*\(\.log\|log.*\.txt\|catalina.out\)$" -type f -print -exec truncate -s 0 {} \;
  if [ $? -eq 0 ]; then
    echo -e `date`" truncate logs successfully! \n"
  else
    echo -e `date`" truncate logs failed! \n"
  fi
done

 【删除日志文件】脚本如下:

#!/bin/sh
#可填写多个路径
workdir=("/home/mppay/apache-tomcat-7.0.73/logs" "/home/mppay/logs")
for wdir in ${workdir[@]}; do
  echo -e "filepath is ${wdir}"
  # .log 文件和包含 log 标记的 .txt文件,以及 catalina.out 文件
  find $wdir -regex "^.*\(\.log\|log.*\.txt\|catalina.out\)$" -and -mtime +5 -type f -exec  rm  -rf  {} \;if [ $? -eq 0 ]; then
    echo -e `date`" delete logs successfully! \n"
  else
    echo -e `date`" delete logs failed! \n"
  fi
done
  • 命令说明:

    find 路径 -name "文件名" -type f -print -exec truncate -s 0 {} ;  #清空文件内容

    find 路径 -mtime +天数 -type f -name "文件名" -exec rm -rf {} ;    #删除文件

    find:Linux查找命令,用户查找指定条件的文件 -regex:此参数表示后面的输入使用正则表达式进行书写。若为 -name 则后面使用一般字符串书写,此时可以使用通配符,但正则相关的符号将会被保留。     shell正则:^ 表示正则匹配字符串开头,$ 表示正则匹配字符串的结尾,其他一些和正则使用的非字母的符号需要进行转义;. 表示匹配任意字符;所以文件路径中出现的 . 需要进行转义。 -and:表示再次同等使用命令的相关参数,如此处的 -mtime ; -mtime:表示使用修改时间属性,后面的 +7 表示满足超过7天,即修改时间在7天以上的文件或文件夹;而 -7 表示满足不足7天, 7 表示刚好7天; -type:表示查找的文件属性,后面 f 表示查找文件,而 d 表示查找文件夹; -print:将符合的文件打印出来; -exec:表示后面要对前面匹配的文件或文件夹执行后面的命令。注意后面的命令需要一对儿{},一个空格和一个,最后是一个分号来结束;

2、crontab计划任务

将 auto-truncate-log.sh 执行脚本加入到系统计划任务,定时自动执行:

crontab -e

输入:

* */1 * * * /home/mppay/auto-truncate-log.sh >> /home/mppay/auto-truncate-log.log

这里设置每隔1小时执行auto-truncate-log.sh文件进行日志清理任务,同时指定的日志输出。

执行结果:

Linux——定时清空日志内容和删除日志文件

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
3个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Stella981 Stella981
3年前
Spring Boot日志集成
!(https://oscimg.oschina.net/oscnet/1bde8e8d00e848be8b84e9d1d44c9e5c.jpg)SpringBoot日志框架SpringBoot支持JavaUtilLogging,Log4j2,Lockback作为日志框架,如果你使用star
Wesley13 Wesley13
3年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Stella981 Stella981
3年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Stella981 Stella981
3年前
Linux日志安全分析技巧
0x00前言我正在整理一个项目,收集和汇总了一些应急响应案例(不断更新中)。GitHub地址:https://github.com/Bypass007/EmergencyResponseNotes本文主要介绍Linux日志分析的技巧,更多详细信息请访问Github地址,欢迎Star。0x01日志简介Lin
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
9个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这