linux日志文件删除

业务场景:

       系统中各个脚本都会生成大量的log脚本,此时需要出一个脚本删除某一日期之前的日志(暂定保留30天)。

代码思路:

       1、找到该部分日志文件。

       2、删除这部分日志文件。

代码实现:

find /data/log/* -name *log -mtime +30 -exec rm -f {} \;

拓展 Linux find命令1

       1、用法简介

       Linux find 命令用来在指定目录下查找文件。任何位于参数之前的字符串都将被视为欲查找的目录名。如果使用该命令时,不设置任何参数,则 find 命令将在当前目录下查找子目录与文件。并且将查找到的子目录和文件全部进行显示。

       2、语法

find   path   -option   [   -print ]   [ -exec   -ok   command ]   {} \;

       3、参数说明

find 根据下列规则判断 path 和 expression,在命令列上第一个 - ( ) , ! 之前的部份为 path,之后的是 expression。如果 path 是空字串则使用目前路径,如果 expression 是空字串则使用 -print 为预设 expression。
expression 中可使用的选项有二三十个之多,在此只介绍最常用的部份。
-mount, -xdev : 只检查和指定目录在同一个文件系统下的文件,避免列出其它文件系统中的文件
-amin n : 在过去 n 分钟内被读取过
-anewer file : 比文件 file 更晚被读取过的文件
-atime n : 在过去 n 天内被读取过的文件
-cmin n : 在过去 n 分钟内被修改过
-cnewer file :比文件 file 更新的文件
-ctime n : 在过去 n 天内创建的文件
-mtime n : 在过去 n 天内修改过的文件
-empty : 空的文件-gid n or -group name : gid 是 n 或是 group 名称是 name
-ipath p, -path p : 路径名称符合 p 的文件,ipath 会忽略大小写
-name name, -iname name : 文件名称符合 name 的文件。iname 会忽略大小写
-size n : 文件大小 是 n 单位,b 代表 512 位元组的区块,c 表示字元数,k 表示 kilo bytes,w 是二个位元组。
-type c : 文件类型是 c 的文件。
d: 目录
c: 字型装置文件
b: 区块装置文件
p: 具名贮列
f: 一般文件
l: 符号连结
s: socket
-pid n : process id 是 n 的文件
你可以使用 ( ) 将运算式分隔,并使用下列运算。
exp1 -and exp2
! expr
-not expr
exp1 -or exp2
exp1, exp2

       4、实例

将当前目录及其子目录下所有文件后缀为 .log 的文件列出来:

 find . -name "*.log"

将当前目录及其子目录中的所有文件列出:

 find . -type f

将当前目录及其子目录下所有最近 20 天内更新过的文件列出:

 find . -ctime  20

查找 /var/log 目录中更改时间在 30 日以前的普通文件,并在删除之前询问它们:

 find /var/log -type f -mtime +30 -ok rm {} \;

查找当前目录中文件属主具有读、写权限,并且文件所属组的用户和其他用户具有读权限的文件:

 find . -type f -perm 644 -exec ls -l {} \;

查找系统中所有文件长度为 0 的普通文件,并列出它们的完整路径:

 find / -type f -size 0 -exec ls -l {} \;

  1. 参考来源:https://www.runoob.com/linux/linux-comm-find.html ↩︎

  • 4
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Linux系统中,我们可以使用一些命令和方法来查看被删除文件的记录。 首先,我们可以使用命令`ls`来查看目录中被删除文件。通过在命令中添加`-a`选项,可以显示所有文件,包括隐藏文件。使用`ls -l`命令可以显示文件的详细信息,包括文件的权限、所有者、大小和修改日期等。如果我们注意到某个文件或目录突然消失,我们可以尝试使用`ls`命令来查看是否有被删除的记录。 其次,Linux系统中有一个特殊的目录`/var/log`用于存储系统日志文件。我们可以进入该目录,查看`/var/log/syslog`或`/var/log/messages`等常见的日志文件,查找关于文件删除的记录。使用`cat`命令或`less`命令可以打开这些日志文件,然后使用关键词搜索来定位被删除文件的相关信息。 另外,Linux系统还提供了一些工具来恢复被删除文件,如`extundelete`和`testdisk`等。这些工具可以扫描文件系统,并尝试恢复被删除文件。使用这些工具需要以root权限运行,并且需要在文件删除之后尽快使用,因为随着时间的推移,文件可能会被重写或覆盖。 总之,在Linux系统中查看被删除文件的记录可以通过使用`ls`命令查看目录,查看系统日志文件以及尝试使用恢复工具来实现。但需要注意的是,只有在文件删除之后尽快采取行动,才能提高恢复被删除文件的成功率。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

D2cOneluo

万一有大佬给个打赏呢,对不对。

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值