find
find 用来在指定目录下查找文件。任何位于参数之前的字符串都将被视为欲查找的目录名。如果使用该命令时,不设置任何参数,则 find 命令将在当前目录下查找子目录与文件。并且将查找到的子目录和文件全部进行显示。
语法
find path -option [ -print ] [ -exec -ok command ] {} \;
上面的 find的常用形式可以简化为:
find [path...] [expression]
- path:所查找的目录路径。例如,用.来表示当前目录,用/来表示系统根目录
- expression:可以分为 “-options [-print -exec -ok ...]”
-options
,指定find命令的常用选项,下节详细介绍-print
,find命令将匹配的文件输出到标准输出-exec
,find命令对匹配的文件执行该参数所给出的shell命令。相应命令的形式为'command' { } \;
,注意{ }和\;之间的空格find ./ -size 0 -exec rm {} \;
删除文件大小为零的文件 (还可以以这样做:rm -i find ./ -size 0
或find ./ -size 0 | xargs rm -f &
)- 为了用ls -l命令列出所匹配到的文件,可以把ls -l命令放在find命令的-exec选项中:
find . -type f -exec ls -l { } \;
在/logs目录中查找更改时间在5日以前的文件并删除它们:find /logs -type f -mtime +5 -exec rm { } \;
-ok
,和-exec
的作用相同,只不过以一种更为安全的模式来执行该参数所给出的shell命令,在执行每一个命令之前,都会给出提示,让用户来确定是否执行。find . -name "*.conf" -mtime +5 -ok rm { } \;
在当前目录中查找所有文件名以.conf结尾、更改时间在5日以上的文件,并删除它们,只不过在删除之前先给出提示
参数
expression 中可用选项非常之多
- -mount, -xdev : 只检查和指定目录在同一个文件系统下的文件,避免列出其它文件系统中的文件
- -amin n : 在过去 n 分钟内被读取过
- -anewer file : 比文件 file 更晚被读取过的文件
- -atime n : 在过去n天内被读取过的文件
- -cmin n : 在过去 n 分钟内被修改过
- -cnewer file :比文件 file 更新的文件
- -ctime 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 | 套接字文件 |
实例
(1)根据文件名查找
-name //根据文件名查找(精确查找) -iname //根据文件名查找,但是不区分大小写
这里另外介绍下文件名通配符的知识
*表示通配任意的字符
find /etc -name "*passwd"
?表示通配任意的单个字符
find /etc -name "passwd?"
[ ] 表示通配括号里面的任意一个字符
find /etc -name "[ab].sh"
(2)根据文件所属用户和组来查找文件
-user //根据属主来查找文件 -group //根据属组来查找文件
(3)根据 uid 和 gid来查找用户
find /tmp -uid 500 //查找uid是500 的文件 find /tmp -gid 1000 // 查找gid是1000的文件
(4)-a and -o and –not的使用
ps:有用
-a 连接两个不同的条件(两个条件必须同时满足) -o 连接两个不同的条件(两个条件满足其一即可) -not 对条件取反的
find /tmp -name "*.sh" -a -user root find /tmp -not -user root
(5)根据文件时间戳的相关属性来查找文件
可以使用stat命令来查看一个文件的时间信息
如下:
stat /etc/passwd
-atime -mtime -ctime -amin -mmin -cmin
所以这里atime, mtime, ctime就是分别对应的 “最近一次访问时间” “最近一次内容修改时间” “最近一次属性修改时间”,这里的atime的单位指的是“天”,amin的单位是分钟
find /tmp –atime +5 //表示查找在五天内没有访问过的文件(也就是5天前天没访问的文件) find /tmp -atime -5 //表示查找在五天内访问过的文件
ps:在清理日志的时候,一般使用的是——最近一次内容修改的时间
find -mtime +30 -name "*[0-9]*" -exec rm {} \;
(6)根据文件类型来查找文件 -type
f // 普通文件 d //目录文件 l //链接文件 b //块设备文件 c //字符设备文件 p //管道文件 s //socket文件
find /tmp -type s
(7)根据大小来查找文件 -size
find /tmp -size 2M //查找在/tmp 目录下等于2M的文件 find /tmp -size +2M //查找在/tmp 目录下大于2M的文件 find /tmp -size -2M //查找在/tmp 目录下小于2M的文件
(8)根据文件权限查找文件 -perm
find /tmp -perm 755 //查找在/tmp目录下权限是755的文件 find /tmp -perm +222 //表示只要有一类用户(属主,属组,其他)的匹配写权限就行 find /tmp -perm -222 //表示必须所有类别用户都满足有写权限
(9)-nouser and -nogroup
find / -nogroup –a –nouser //在整个系统中查找既没有属主又没有属组的文件(这样的文件通常是很危险的,作为系统工程师的我们应该及时清除掉)
查找完执行的action
-print //默认情况下的动作 -ls //查找到后用ls 显示出来 -ok [commend] //查找后执行命令的时候询问用户是否要执行 -exec [commend] //查找后执行命令的时候不询问用户,直接执行
find /tmp -name "*.sh" -exec chmod u+x {} \;
这里要注意{}的使用:替代查找到的文件
find /tmp "*.sh" -exec cp {} {}.old \;
删除查找到的超过30天没有访问过文件
find /tmp -atime +30 –exec rm –rf {} \;
也可以使用xargs来对查找到的文件进一步操作
find /tmp -name "*.old" | xargs chmod 700
案例详细说明
- 删除文件命令
find 对应目录 -mtime +天数 -name "文件名" -exec rm -rf {} \;
- 实例命令
find /opt/soft/log/ -mtime +30 -name "*.log" -exec rm -rf {} \;
- 说明
将 /opt/soft/log/ 目录下所有30天前带".log"的文件删除。具体参数说明如下:
- find linux的查找命令,用户查找指定条件的文件;
- /opt/soft/log/:想要进行清理的任意目录;
- -mtime:标准语句写法;
- +30:查找30天前的文件,这里用数字代表天数;
- "*.log":希望查找的文件名正则表达式,"*.jpg"表示查找扩展名为jpg的所有文件,
"*"
表示查找所有文件,这个可以灵活运用,举一反三; - -exec:固定写法;
- rm -rf:强制删除文件,包括目录;
- {} ; :固定写法,一对
大括号
+空格
+\
+;