linux 之 find 查找命令
2016-07-26 20:54
239 查看
文件查找: 在文件系统上查找符合条件的文件 实现工具:locate,find locate:依赖事先构建好的索引库 系统自己实现(周期性任务) 手动更新数据库(updatedb) 工作特性: 查找速度快 模糊查找 非实时查找 locate 命令: locate [OPTION]... PATTERN... -b: 只匹配路径中的基名 -c: 统计出共有多少个符合条件的文件 -r: BRE find 命令: 文件的实时查找文件的工具,通过遍历指定路径 下文件系统层级结构完成文件的查找 工作特性: 查找速度很慢 精确查找 实时查找 用法: find [-H] [-L] [-P] [-D debugopts] [-Olevel] [path...] [expression] find [OPTIONS] [查找起始路径][查找条件][处理动作] 查找起始路径:指定具体搜索目标的起始路径,默认为当前目录 查找条件:指定的查找标准,可以根据文件名,大小,类型,从属关系,权限等等标准进行,默认为找出路径下的所有符合条件的文件 处理动作:对符合查找条件的文件作出的操作,例如删除等操作,默认为输出值标准输出 查找条件: 表达式:选项和测试 测试:结果通常为Boolean型 根据文件名查找: -name "pattern" -iname "pattern" //不区分大小写 支持glob风格的通配符 -regex pattern:基于正则表达式模式查找文件,匹配整个路径,而非文件名 根据文件的从属关系查找: -user username:查找属主为指定用户的所有文件 -group groupname:查找属组为指定组的所有文件 -uid uid:查找属主为指定UID所有文件 -gid gid :查找属组为指定GID的所有文件 -nouser:查找没有属主的文件 -nogroup:查找没有属组的文件 根据文件类型查找: -type TYPE: f:普通文件 d:目录文件 l:符合链接文件 b:块设备文件 c:字符设备文件 p:管道文件 s:套接字文件 组合测试: 与:-a 或:-o 非:-not,! 根据文件大小查找 -size[+|-]#UNIT 常用单位:k,m,g #UNIT:(#-1,#] -#UNIT:[0,#-1) +#UNIT:(#,OO) 根据时间戳查找: 以天为单位: -atime [+|-]# #:[#,#-1) -#:(#,0] +#:(00,#-1] -mtime -ctime 以分钟为单位: -amin -mmin -cmin 根据权限查找: -perm [/|-]mode mode :精确权限匹配 /mode:任何一类用户(u,g,)的权限中的任何一位(r,w,x)符合条件既满足 9位权限之间存在或的关系 -mode:每一类用户(u,g,o)的权限中的任何一位(r,w,x)同时符合条件既满足 9位权限之间存在与的关系 处理动作: -print: 输出至标准输出,默认的动作; -ls:类似于对查找到的文件执行“ls -l”命令,输出文件的详细信息 -delete:删除查找到的文件 -fls /PATH/SOMEFILE:把查找的文件信息保存到文件中 -ok COMMAND{}\; :对查找到的文件执行COMMAND 的命令,每次操作都有用户确认 -exec COMMAND{}\; :对查找到的文件执行COMMAND的命令,直接修改完成 注意:find传递查到的文件路径至后面的命令时,是先查找出所有符合条件的文件路径,并一次性传递给后面的命令 但是有些命令不能接受过长的参数,此命令会执行失败,另一种方式可规避此问题: find | xargs COMMAND 练习: 1.查找/var目录下属主为root,且属组为mail的所有文件或目录 find /var -user root -group mail -ls 2.查找/usr目录下不属于root,bin或hadoop的所有文件或目录;用两种方法 find /usr -not \( -user root -o -user bin -o -user hadoop \) -ls find /usr -not -user root -a -not -user bin -a -not -user hadoop -ls 3.查找/etc目录下最近一周内其内容修改过,且属主不是root也不是hadoop用户的文件或目录 find /etc -not -user root -a -not -user hadoop -a -mtime -7 -ls 4.查找当前系统上没有属主或属组,且最近一周内曾被访问过的文件或目录 find / -nouser -o -nogroup -ls -atime -7 5.查找/etc目录下大于1M且类型为普通文件的所有文件 find /etc -size +1M -type f `-exec ls{}\;` 6.查找/etc目录下所有用户都没有写权限的文件 find /etc -not -perm /222 -type f -ls 7.查找/etc目录至少有一类用户没有执行权限的文件 find /etc/ -not -perm -111 -type f -ls 8.查找/etc/init.d/目录下,所有用户都有执行权限,且其他用户有写权限的所有文件 find /etc/init.d -perm -113 -type f -ls
相关文章推荐
- linux 服务器时间同步
- 如何创建centos虚拟机下面的磁盘分区
- LVM逻辑盘卷管理
- linux初体验
- LINUX入门基础
- Linux下突破限制实现高并发量服务器
- linux之使用帮助
- LINUX入门基础
- Ubuntu上搭建samba服务器并远程挂载
- Android 在 SElinux下 如何获得对一个内核节点的访问权限
- linux基础学习-第三天记录
- linux基础1
- linux文件系统及文件属性
- Linux常见知识
- linux 下删除乱码的文件夹
- linux 命令 ln(软件升级很好用)
- Linux系统查看当前主机CPU、内存、机器型号及主板信息
- virtualbox虚拟机下的cdlinux找不到无线网卡的解决方法
- man帮助history的使用以及linux文件系统。
- magedu Linux 运维学习的第三天