Linux下which、locate、find 命令查找文件

Linux下我们经常要查找某个文件,但是又不记得文件位置,可以使用一些命令来搜索,目前接触到的文件命令有以下几个

which 查看可执行文件的位置

locate 基于数据库查找文件位置

find 实时搜索文件

1、 Which

  语法:which 可执行二进制文件名称

Linux下which、locate、find 命令查找文件

  Linux下which、locate、find 命令查找文件

Which是通过PATH环境变量查找文件的,在PATH 指定的路径中,搜索某个命令的位置,也就是说使用which命令,就可以看到某个系统命令是否存在,以及执行的到底是哪个位置的命令

注:对于一些命令使用which也查不出结果。有以下两种可能

(1    (1) 命令所在的目录不在PATH的查找路径范围内

(     (2) 命令属于是内部命令,可以使用type命令确认命令类型

2、Locate

   locate命令用于查找文件,优点是搜索速度快,缺点是基于数据库查找,缺乏实时性,而且是模糊查找。它在查找的时候需要一个数据库,这个数据库是由每天的例行工作(crontab)程序来建立。当我们建立好这个数据库后,就可以方便地来搜寻所需文件了。

  即先运行:updatedb(无论在那个目录中均可,可以放在crontab中 )后在 /var/lib/slocate/ 下生成 slocate.db 数据库即可快速查找。在命令提示符下直接执行#updatedb 命令即可。

语法:locate 文件名

普通查询:搜索包含给定字符串的文件路径

 Linux下which、locate、find 命令查找文件

选项:

   -i 不区分大小写的搜索

   -n X只列举前X个匹配项目

   -r 支持正则表达式

3、Find

根据指定条件查找指定路径(如果不指定路径,默认是当前目录)下的文件或者目录(默认进行递归查询),还可对查询结果进行进一步的操作

工作特点:查询速度较locate较慢(因为是实时查找)

          精准查找

          只能搜索用户具备读取和执行权限的目录

语法 find 路径 参数

参数选项说明

    -maxdepth level 最大搜索

    -mindepth level 最小搜索深度

Linux下which、locate、find 命令查找文件

find命令默认是进行递归查找,如果不行进行递归查找,可以将最大搜索深度设为1  

    -name 基于名称的精确查找 可以使用通配符* 、? [] [^]

Linux下which、locate、find 命令查找文件

    -iname 忽略大小写的查找

Linux下which、locate、find 命令查找文件

    -inum 基于inode号查找

Linux下which、locate、find 命令查找文件

-samefile 基于相同inode号的查找(查找硬链接)

   Linux下which、locate、find 命令查找文件

-links n 硬链接为n的文件

Linux下which、locate、find 命令查找文件 

-regex 支持正则 默认为(emacs标准)不支持[:upper:] [:alnum:],只能用[a-z] [0-9]之类的表达 
Linux下which、locate、find 命令查找文件

-regextype egrep -regex 支持egrep同标准的正则

-user 用户名  基于文件owner的查找

 -group 组名 基于文件group的查找 


 Linux下which、locate、find 命令查找文件

-uid userid 基于文件uid的查找

-gid groupid 基于文件gid的查找

-nouser 查找没有owner的文件

-nogroup 查找没有group的文件

 
Linux下which、locate、find 命令查找文件

-type 基于文件类型的查找

       f: 普通文件

       d: 目录文件

       l: 符号链接文件

       s:套接字文件

       b: 块设备文件

       c: 字符设备文件


Linux下which、locate、find 命令查找文件

根据时间戳查找

以“天”为单位

-atime [+|-]#, 访问时间

     #: [#,#+1)

     +#: [#+1,]

     -#: [0,#)

     -mtime  文件修改时间

         -ctime元数据时间

以“分钟”为单位

-amin 访问时间

-mmin 文件数据修改时间

    -cmin 文件元数据修改时间

-perm

  mode:精确权限匹配(这能匹配到指定权限的文件

Linux下which、locate、find 命令查找文件

  +mode[/mode] 任何一类(u,g,o)对象的权限中只要能一位匹配即可,或关系,+ centos7开始淘汰

Linux下which、locate、find 命令查找文件 

/644 是指匹配owner位上有读写权限或者group位上有读权限或者other位上有读权限的文件

  -mode   每一类对象都必须同时拥有指定权限,与关系 0 表示不关注

Linux下which、locate、find 命令查找文件 

-421 匹配的是owner位上有读权限且group位上有写权限且other位上有执行权限的文件

-delete 直接删除所查找到的文件,不询问。

Linux下which、locate、find 命令查找文件

-ls 长列出所查找到的文件

Linux下which、locate、find 命令查找文件

-ls 属于find命令的一个选项,并不是ls命令查出来的

-ok command \;(结束必须是空格加
\ ’再加 ;)对查找到的文件当做下一命令的参数去执行(交互式)(执行操作的时候每一个步骤会问,尤其是执行删除操作的时候使用这种方式可以防止误删除)

-exec command \; 对查找到的文件当做下一命令的参数去执行(非交互式)
(直接执行不会询问,当执行删除操作时不安全)

xargs 用于产生某个命令的参数,xargs可以读入stdin的数据,并且以空格符或回车符将stdin的数据分隔成为argumentLinux下which、locate、find 命令查找文件

使用这种可以大批量删除一些文件,因为如果文件过多使用rm
–rf *
是删不掉的,可以使用这种方法将参数一个一个的传递给rm命令 ,实现大批量删除
  

练习:

1、查找/var目录下属主为root,且属组为mail的所有文件

    find /var -user root -a -group mail -ls

2、查找/var目录下不属于rootlpgdm的所有文件

    find /var -not \( -user root -o -user lp -o -user gdm \) -ls

3、查找/var目录下最近一周内其内容修改过,同时属主不为root,也不是postfix的文件

    find /var/ -mtime -7 -not -user root -not -user postfix -ls

4、查找当前系统上没有属主或属组,且最近一个周内曾被访问过的文件

    find / -nouser -o -nogroup -a -atime -7 -ls

5、查找/etc目录下大于1M且类型为普通文件的所有文件

    find /etc/ -size +1M -a -type f -ls

6、查找/etc目录下所有用户都没有写权限的文件

    find /etc ! -perm /222 -ls

7、查找/etc目录下至少有一类用户没有执行权限的文件

    find /etc ! -perm -111  -ls

8、查找/etc/init.d目录下,所有用户都有执行权限,且其它用户有写权限的文件

    find /etc/init.d/ -perm -113 -ls

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

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

(0)
MelissaMelissa
上一篇 2017-08-13
下一篇 2017-08-14

相关推荐

  • Sed及Vim作业

      Sed及Vim作业题:     1、删除/etc/grub2.conf文件中所有以空白开头的行行首的空白字符    [root@localhost 7 ~]# sed -r  's/^[[:space:]]…

    Linux干货 2016-08-09
  • 强大的vim编辑器

    vim编辑器 一、Vim编译器的概述 vi: Visual Interface,文本编辑器 v 文本:ASCII, Unicode v  文本编辑种类:      行编辑器: sed      全屏编辑器:nano,   &nbs…

    Linux干货 2016-08-12
  • Kernel——linux的核心

    Linux Kernel: CentOS 启动流程:POST –> BootLoader(BIOS,MBR) –>Kernel(initrd) –> rootfs –> switch_root –> /sbin/init     …

    Linux干货 2016-09-11
  • linux下NTP服务

    linnux NTP

    2017-10-18
  • centos7 yum源仓库网络共享

    一般yum源仓库需要两部分组成,一部分为rpm程序包,另一个就是repodata元数据组成。制作一个简单的网络共享yum源仓库,在制作网络共享服务器需要事先配备好你的yum源,以方便使用 1.安装网络共享yum源仓库服务 以ftp为例: (1)在centos7中是否有ftp,用rpm -q 对vsftpd程序包查看 [root@local…

    Linux干货 2017-04-23
  • rsyslog日志系统

    一、前言  什么是日志?    日志就是历史事件,按时间序列将发生的事件予以记录;日志记录信息记录的是事件的发生时间以及事件内容  Linux下记录日志的系统:    syslog:是CentOS 5.0系统上使用的日志系统,有两类日志,分别是syslogd、klogd;    …

    Linux干货 2015-06-15