文件的查找工具find

有的时候我们需要快速查找一些文件,但是我们却不知道这个文件在哪的时候,就急切的需要一个工具来帮助我们,这时候find就诞生了。Find能实现精确查找,虽然速度略慢,但是并不妨碍我们使用,下面就介绍一下find的使用方法。
(一) 基于时间戳的查找
          假如需要查看七天前的文件,但是总不能一一的去看时间查找,这点和windows不一样,windows可能是默认的按时间先后顺序排列的,所以在这里我们就要基于命令去查找了。以天为单位的选项分别有atime,mtime,ctime.
          分别是访问时间,文件数据修改时间,文件元数据修改时间。下面举例说明,以便让大家更好的明白。
          Eg: 查询/app目录下五天以内被访问的文件
  文件的查找工具find
          解释:-atime 就是访问时间,-5就是指0到5天以内的,-ls就是长列出所查到的文件,这里需要说明一下时间的问题。如果是按时间或者天数来算的话,-5是[0,5),意思就是大于等于0  且小于5,+5是[6,无穷),意思就是大于等于6,直接就一个5的话,就是[5,6),意思就是大于等于5且小于6.
(二) 基于文件用户名查找
          假如你想找user是joe的文件,只需选项-user.
          Eg:查找/app下所属人为liubei的文件
 文件的查找工具find
       解释:/app/* 就是查找/app下的文件,不包括app目录本身,小编之前犯了错误,把目录本身也截取下来了,在这里提醒广大用户,不要犯同样的错误,但是如果你想要把目录也一起算的话就把/*去掉就可以了。-user就是基于用户名查找。
(三) 基于文件大小查找
          假如想查找文件大于1M的,只需选项-size
          Eg:查/app下大于1M的文件
          首先看一下app下的文件大小哦,这里文件大于1M的只有a1
 文件的查找工具find
          下面开始截取符合规定的文件
 文件的查找工具find  
          解释:-size就是基于文件大小查找,+1M就是(1,无穷),意思就是大于1M的文件。
(四) 基于文件类型查找
          假如想查找/app下的普通文件,只需选项-type f.
          Eg:查找/app下的目录文件
 文件的查找工具find
          解释:-type就是基于类型查找,d就是目录的意思,f为普通文件,l符号链接文件,S套接字文件,b块设备文件,c字符设备文件。
(五) 基于文件权限查找
          选项是-perm 权限
          Eg:查找/app下有执行权限的文件
 文件的查找工具find
          解释:-perm就是 基于权限的查找,/111意思是ugo任意一位有执行权限就可以。
(六) 基于组名的查找
          选项是 –group 组名
          Eg:查找/app下组名是liubei的文件
 文件的查找工具find
          解释:-group 就是基于组名的查找。
(七) 基于文件uid的查找
         选项是-uid userid
         Eg:查找/app uid为1004的文件
 文件的查找工具find
(八) 基于文件名称的查找
          选项是-name
          Eg:查找/app下 文件名为a开头的文件
 文件的查找工具find
          解释:a*的意思就是以a开头 后面跟任意内容的文件。
(九) 基于没有所属人没有所属组的查找
          假如一个文件所属人,所属组被删除了,但是想查找,就需要这个命令,-nouser  -nogroup
          Eg:查找没有所属组的文件
 文件的查找工具find
          Eg:查找没有所属人的文件
 文件的查找工具find
         解释:-nouser就是没有所属人,-nogroup就是没有所属组
下面给出一些平时的练习,以供参考。
1.查找/var目录下不属于root、lp、gdm的所有文件
解题方法:find /var -not \( -user root -o -user lp -o -user gdm \) -ls
 文件的查找工具find
解题思路:-o就是或的意思,-a就是且的意思,-not就是非的意思。在这里使用了德摩根定理,如下:
(非 A) 或 (非 B) = 非(A 且 B)
(非 A) 且 (非 B) = 非(A 或 B)
所以查找不属于三个用户的文件就是不属于root,也不属于lp,也不属于gdm,所以用-not的话 ,括号里面就要用或的关系,才能保证三个条件都满足。
2.查找当前系统上没有属主或属组,且最近一个周内曾被访问过的文件
 解题方法:find / \( -nouser -o -nogroup \) -a -atime -7 –ls
 文件的查找工具find
解题思路 :使用-o就是或的关系,但是中间要用括号括起来,不然的话后面的-a连着的就只有 –nogroup了,使用\是转义的意思,在这里不能直接识别括号,所以需要转义。
3.查找/etc目录下所有用户都没有写权限的文件
 解题方法:find /etc ! -perm /222 –ls
 文件的查找工具find
解题思路:前面说过/111,这里/222意思和那个是大致一样的,意思就是任意一位有读权限就可以,前面加个!就是非的意思,这里使用德摩根定理,不会的同学可以看一下前面的。

原创文章,作者:lll,如若转载,请注明出处:http://www.178linux.com/84625

(0)
llllll
上一篇 2017-08-13 13:39
下一篇 2017-08-13 15:43

相关推荐

  • linux 中的 文本处理工具

    文本处理工具  在linux系统中 文本工具有很多 现在具体介绍几款 如 抽取文本的工具 和文件三剑客  文件内容:less和 cat   文件截取:head和tail   按列抽取:cut   按关键字抽取:grep egrep 首先 有 查看文件的cat tac  cat [OPTION]&#8…

    Linux干货 2016-08-11
  • MariaDB数据库基于SSL实现远程访问和主从复制

    MariaDB数据库基于SSL实现远程访问和主从复制 实验环境 系统环境:Centos6.5 数据库版本:5.5.36-MariaDB-log MariaDB Server 虚机数量:2 方案实施: 1,配置CA;并为node1和node2生成key和证书 2,在node1和node2上安装Mariadb 3,配置节点1为MariaDB主节点 4,配置节点2…

    Linux干货 2016-05-18
  • 权限(用户、特殊、ACL)

    root权限(id=0) root无论在什么情况下都有rw权限,但是是否拥有x权限,要分情况: 第一,文件所有者和所属组都无x权限,root也无x权限; 第二,文件所有者和所属组二者任何一个有x权限,root就有x权限。 用户得到的权限 匹配顺序:文件所有者——文件所属组——其他人(从左到右) 用户访问文件,一旦按次序匹配成功,其获得的权限就是匹配选项所对应…

    Linux干货 2017-05-30
  • 马哥教育网络班22期+第2周课程练习

    1、Linux上文件/目录相关命令有哪些? 1)目录管理类命令:mkdir、rmdir (1)mkdir:make directorise 创建文件夹  使用格式:      mkdir [OPTION]… DIRECTORY…    &nb…

    Linux干货 2016-09-08
  • CentOS 6开机启动流程实验篇

    CentOS 6开机启动流程实验篇 centos 系统的启动流程 grub 破坏Linux的核心文件再修复体验系统启动流程 CentOS 6开机启动的具体详情请参见理论篇! 了解了系统启动的基本流程,以下我们通过“破坏式实验”,即破坏系统启动过程中的一些关键环节,使系统无法启动,然后我们再通过修复这些文件使得系统正常重启,进而体验Linux系统的启动流程,这…

    Linux干货 2016-09-19
  • 马哥教育网络班22期+第8周课程练习 忍者乱太郎喻成

    第八周 1、请描述网桥、集线器、二层交换机、三层交换机、路由器的功能、使用场景与区别。 一个好的链接,主要的参考http://www.cnblogs.com/imapla/archive/2013/03/12/2955931.html简单的总结和自己的理解桥接器(network bridge),又称网桥,一种网络设备,负责网络桥接(network …

    Linux干货 2016-12-26