前言:在很多时候我们都需要通过条件查找所需要的文件。灵活的使用查找文件工具能够事半功倍。
内容:
文件查找:
1.locate:
非实时,模糊匹配,查找是根据全系统文件数据库进行的;
# updatedb, 手动生成文件数据库
优点:速度快
2.find:
- 优点: 实时
精确
支持众多查找标准
- 缺点:
遍历指定目录中的所有文件完成查找,速度慢;
- find查找基础:
find 查找路径 查找标准 查找到以后的处理运作
查找路径:默认为当前目录
查找标准:默认为指定路径下的所有文件
处理运作:默认为显示
- 匹配标准:
-name ‘FILENAME‘:对文件名作精确匹配
文件名通配:
*:任意长度的任意字符
?
[]
- -iname ‘FILENAME‘: 文件名匹配时不区分大小写
- -regex PATTERN:基于正则表达式进行文件名匹配 注意:正则表达式这里是全部的匹配,
比如:find - /etc -name ‘passwd‘
/etc/pam.d/passwd
/etc/passwd
find /etc - regex ‘passwd‘这个是不会匹配任何的内容的。
find /etc -regex ‘/etc/passwd‘这个谁匹配唯一。
/etc/passwd
- -user USERNAME: 根据属主查找
- -group GROUPNAME: 根据属组查找
- -uid UID: 根据UID查找(当UID所对应的用户删除后,就只剩下了UID的号,这是方便查找哪些被删除用户的残留文件。)
- -gid GID: 根据GID查找(同上)
- -nouser:查找没有属主的文件
- -nogroup: 查找没有属组的文件
- -type
f: 普通文件
d:目录
c:字符文件
b:块设备
l:链接文件
p:管道
s:套接字
- -size [+|-] (只要是符合标准的都可以显示,包括子目录例如:父目录满足条件,如果要是子目录中有满足条件的可以被查找到)
#k(例如:10k那么9-10k的都会显示,他是会认为9k多的也是10k)
#M
#G
- 组合条件:(默认是与)
-a
-o
-not
/tmp目录,不是目录,并且还不能套接字类型的文件
注意:这个是可以组合使用的例如:find /tmp/ -not \( -type d -o -type s \) 等价于
find /tep/ -not -type d -not -type s
/tmp/test目录下,属主不是user1,也不是user2的文件;
- 按照时间查询:
按照天数
-mtime:修改时间
-ctime:改变时间
-atime:进入时间
[+|-]#
按照分钟数:
-mmin
-cmin
-amin
[+|-]#
- 按照权限查找
-perm MODE:精确匹配
/MODE: 任意一位匹配即满足条件
-MODE: 文件权限能完全包含此MODE时才符合条件
-644
644: rw-r--r--
755: rwxr-xr-x
750: rwxr-x---
find ./ -perm -001
- 处理动作:
-print: 显示
-ls:类似ls -l的形式显示每一个文件的详细
-ok COMMAND {}(这里是占位符表示查询的结果) \; 每一次操作都需要用户确认
-exec COMMAND {} \;
练习:
1、查找/var目录下属主为root并且属组为mail的所有文件;
find /var -user root -group mail
2、查找/usr目录下不属于root,bin,或student的文件;
find /usr -not -user root -a -not -user bin -a -not -user student
find /usr -not \( -user root -o -user bin -o -user student \)
3、查找/etc目录下最近一周内内容修改过且不属于root及student用户的文件;
find /etc -mtime -7 -not \ ( -user root -o -user student \)
find /etc -mtime -7 -not -user root -a -not -user student
4、查找当前系统上没有属主或属组且最近1天内曾被访问过的文件,并将其属主属组均修改为root;
find / \( -nouser -o -nogroup \) -a -atime -1 -exec chown root:root {} \;
5、查找/etc目录下大于1M的文件,并将其文件名写入/tmp/etc.largefiles文件中;
find /etc -size +1M >> /tmp/etc.largefiles
find /etc/ -size +1M -exec echo {} >> /tmp/etc.largefiles \;
6、查找/etc目录下所有用户都没有写权限的文件,显示出其详细信息;
find /etc -not -perm /222 -ls
xargs这个命令可以总做在find后面(可以不用占位符,输出的结果不是每行一个,而是用空格隔开)
例如;find /etc -size +1M |xargs echo >> /tmp/etc.largefiles
总结:find的功能还是很强大的。