在文件系统上查找符合条件的文件;
文件查找:定位,找到
非实时查找(数据库查找):定位
实时查找:找到
定位:
依赖于事先构建的索引;索引的构建是在系统较为空闲时自动进行(周期性任务);手动更新数据库(更新资料库);
索引构建过程需要遍历整个根文件系统,极消耗资源;
工作特点:
查找速度快;
模糊查找;
非实时查找;
定位关键字
:
实时查找工具,通过遍历指定路径下的文件系统完成文件查找;
工作特点:
查找速度略慢;
精确查找;
实时查找;
语法:
找到[选项]…(查找路径][查找条件][处理动作]
查找路径:指定具体目标路径;默认为当前目录;
查找条件:指定的查找标准,可以文件名,大小,类型,权限等标准进行;默认为找出指定路径下的所有文件;
处理动作:对符合条件的文件做什么操作,默认输出至屏幕;
查找条件:
根据文件名查找:
- name”文件名称“:支持使用一滴
*, ? [], [^]
- iname”文件名称“:不区分字母大小写
正则表达式“模式”:以模式匹配整个文件路径字符串,而不仅仅是文件名称;
根据属主,属组查找:
用户用户名:查找属主为指定用户的文件;
集团GRPNAME:查找属组为指定组的文件;
UID UserID:查找属主为指定的UID号的文件;
GID GroupID:查找属组为指定的GID号的文件;
-nouser:查找没有属主的文件;
-nogroup:查找没有属组的文件;
根据文件类型查找:
类型类型:
f:普通文件
d:目录文件
l:符号链接文件
s:套接字文件
b:块设备文件
c:字符设备文件
p:管道文件
组合条件:
与
: -或:- o
非:不是,!
!——! B=! (A - o B)
!- o ! B=! (A - B)
找出/tmp目录下,属主不是根,且文件名不是这个的文件;
找到/tmp \(——用户根————- name '这个' \)- ls
找到/tmp——\(用户根- o - name '这个' \)- ls
根据文件大小来查找:
造[+ | -]#单元
常用单位:k、M G
#单元:(# 1,#)
- #单元:[0,1]
+ #单元:(#,oo)
根据时间戳:
以“天”为单位;
atime + | - #,,
#: [#, # + 1)
+ #:【# + 1, oo)
- #: [0 #)
-mtime -ctime
以“分钟”为单位:
阿明
-mmin -cmin
根据权限查找:
烫[/| -]模式
模式:精确权限匹配
/模式:任何一类(u G o)对象的权限中只要能一位匹配即可。
模式:每一类对象都必须同时拥有为其指定的权限标准;
处理动作:
安全性:默认的处理动作,显示至屏幕;
- ls:类似于对查找到的文件执行ls - l”命令;
删除:删除查找到的文件;
fls的/道路//somefile:查找到的所有文件的长格式信息保存至指定文件中,
-好的命令{}\;对查找到的每个文件执行由命令指定的命令;
对于每个文件执行命令之前,都会交互式要求用户确认;
- exec命令{}\;对查找到的每个文件执行由命令指定的命令,,
{}:用于引用查找到的文件名称自身;
注意:找到传递查找到的文件至后面指定的命令时,查找到所有符合条件的文件一次性传递给后面的命令;
有些命令不能接受过多参数,此时命令执行可能会失败;另一种方式可规避此问题:
找到| xargs COMMAND
练习:
1,查找/var目录下属主为根,且属组为邮件的所有文件或目录;
#发现/var用户根群邮件
2,查找/usr目录下不属于根,本或hadoop的所有文件或目录;
#发现/usr——用户根————用户本————用户hadoop
#发现/usr——\(用户根- o用户本- o用户hadoop \)
3,查找/etc目录下最周一周内其内容修改过,同时属主不为根,也不是hadoop的文件或目录;
#发现/etc -mtime 7根————————用户用户hadoop
/etc/-mtime 7 #发现————\(用户根- o用户hadoop \)
4,查找当前系统上没有属主或属组,且最近一个周内曾被访问过的文件或目录;