文件查找相关:whereis、find和locate

    本文将对findlocate进行详细讲解

命令简介

  • 名称:whereis

    功能:定位文件所在的目录

    用法:whereis shell命令

    注意:whereis是根据环境变量PATH来查找文件的,而PATH通常设置成存放命令的那些路径,如/bin、/usr/bin等。因此whereis的用途仅限于定位shell命令所在的位置。

  • 名称:find

    功能:查找文件

    用法:find -name 文件名

  • 名称:locate

    功能:查找文件或目录

    用法:locate 文件名或目录名

    说明:locate默认是不被安装的,它的包名叫:mlocate 可以直接使用yum安装即可。locate也是系统中查找文件的方法,但它并不是从磁盘中实时查找文件,而是到由updatedb命令产生的信息库中查找相应的文件和目录。

    注意:如果locate找不到某个文件,但确定该文件存在时,是由于updatedb生成的信息库已经过时。此时你只需要以root的身份执行updatedb命令,重新建立整个系统所有文件和目录的资料库。

命令详解之find

  • 前言

    由于find具有强大的功能,所以它的选项也很多。find命令是一个非常消耗资源的命令,我们用它的时候要习惯于把它放在后台执行,因为遍历一个大的文件系统可能会花很长的时间。

  • 命令格式

    一、find命令的一般形式为:

        find pathname -options [-print -exec -ok …]

    二、find命令的参数:

        pathname:find命令所查找的目录路径。用.来表示当前目录,用/来表示系统根目录。

       -print:find命令将匹配的文件输出到标准输出。

       -exec:find命令对匹配的文件执行该参数所给出的shell命令。

           格式:'command' {} \;    #注意{}和\;之间有空格!

       -ok:在执行每一个命令之前,都会给出提示,让用户确定是否执行。和-exec的作用相同。

    三、find命令选项:

       -name:按照文件名查找文件。

       -perm:按照文件权限查找文件。

       -prune:使find命令不在当前指定的目录中查找。

       -user:按照文件属主查找文件。

       -nouser:查找无有效属主的文件,即该文件的属主在/etc/passwd中不存在。

       -group:按照文件属组查找文件。

       -nogroup:查找无有效属组的文件,即该文件所属的组在/etc/groups中不存在。

       -mtime -n|+n:按照文件的更改时间来查找文件。

           -n:表示文件更改时间距现在n天以内。

           +n:表示文件更改时间距现在n天以前。

       -newer file1 ! file2:查找更改时间比文件file1新但比文件file2旧的文件。

       -type:查找某一类型的文件。

       -size n [c][/c]:查找文件长度为n块文件,带有c时表示文件长度以字节计算。

       -depth:在查找文件时,首先查找当前目录中的文件,然后再在其子目录中查找。

       -fstype:查找位于某一类型文件系统中的文件,这些文件系统类型通常可以在配置文件/etc/fstab中找到,该配置文件中包含了本系统中有关文件系统的信息。

       -mount:在查找文件时不跨越文件系统mount点。

       -follow:如果find命令遇到符号链接文件,就跟踪至链接所指向的文件。

       -cpio:对匹配的文件使用cpio命令,将这些文件备份到磁带设备中。

    四、使用exec或ok来执行shell命令

    exec选项后面跟随着所要执行的命令或脚本,格式:'command' {} \;

    为了使用exec选项,必须要同时使用print选项。如果验证find命令,会发现该命令只输出从当前路径起的相对路径及文件名。

    例如:为了用ls -l命令列出所匹配到的文件,可以把ls -l命令放在find命令的-exec选项中。

[root@localhost ~]# find . -type f -exec ls -l {} \;
-rw-r--r--. 1 root root 18 May 20  2009 ./.bash_logout
-rw-------. 1 root root 38 Feb 26 14:04 ./.lftp/rl_history
-rw-------. 1 root root 12428 Mar 26 19:41 ./.bash_history
-rw-r--r--. 1 root root 129 Dec  4  2004 ./.tcshrc
-rw-r--r--. 1 root root 9562 Feb 23 05:48 ./install.log
-rw-------. 1 root root 35 Feb 24 11:41 ./.lesshst
-rw-------. 1 root root 1122 Feb 23 05:48 ./anaconda-ks.cfg
-rw-r--r--. 1 root root 176 May 20  2009 ./.bash_profile
-rw-r--r--. 1 root root 176 Sep 23  2004 ./.bashrc
-rw-r--r--. 1 root root 100 Sep 23  2004 ./.cshrc
-rw-r--r--. 1 root root 3161 Feb 23 05:47 ./install.log.syslog
-rw-------. 1 root root 4205 Mar 25 12:10 ./.viminfo

    在上面例子中,find命令匹配到了当前目录下的所有普通文件,并在-exec选项中使用ls -l命令将它们列出。

    在shell中用任何方式删除文件之前,应当先查看相应的文件,使用-exec选项执行rm命令时,它会在删除之前先给出提示。如下:

[root@localhost /]# find . -name "*.conf" -mtime +1 -ok rm {} \;
< rm ... ./usr/share/dracut/modules.d/98syslog/rsyslog.conf > ?

    按y键删除文件,按n键不删除。

    同样还能使用grep命令。如下:

[root@localhost /]# find /etc -name "passwd" -exec grep "root" {} \;
root:x:0:0:root:/root:/bin/bash
operator:x:11:0:operator:/root:/sbin/nologin

    上面的例子中,find命令首先匹配所有文件名为passwd的文件,然后执行grep命令看看这些文件中是否存在一个root用户。

    五、find命令其他用法

    1、根据文件特征查询:

       -amin n:查找系统中最后n分钟访问的文件

       -atime n:查找系统中最后n*24小时访问的文件

       -cmin n:查找系统中最后n分钟被改变状态的文件

       -ctime n:查找系统中最后n*24小时被改变状态的文件

       -false:查找系统中总是错误的文件

       -empty:查找系统中空白的文件,或空白的文件目录,或目录中没有子目录的目录

       -fstype type:查找系统中存在于指定文件系统的文件,例如:ext2

       -gid n:查找系统中文件数字组ID为n的文件

       -group gname:查找系统中文件属于gname文件组,并且指定组和ID的文件

    find命令功能强大,我并没有更加详细的说明。参考有关Linux有关书籍可以知道所有find命令的查找函数。

命令详解之locate

    locate让使用者可以很快速的搜寻档案系统内是否有指定的档案。其方法是先建立(使用updatedb命令)一个包括系统内所有档案名称及路径的数据库,之后寻找时就只需要查询这个数据库,而不必实际深入系统之中了。

    在一般的distribution中,数据库的建立都被放在contab中自动执行。一般使用者在使用时是要用下面的命令即可。

[root@localhost /]# locate your_file_name
    • 参数说明

     -u,-U:建立数据库,-u会由根目录开始,-U则可以指定开始的位置。

     -e:将目录排除在寻找的范围之外。

     -l:如果是1,则启动安全模式。在安全模式相爱,使用者不会看到权限无法看到的文件。

     -f:将特定的档案系统排除在外。

     -q:安静模式,不会显示任何错误讯息。

     -n:至多显示n个输出。

     -o:指定数据库存的名称。

     -d:指定数据库的路径。

     -h:显示辅助讯息。

     -v:显示更多讯息。

     -V:显示程序的版本信息。

    • 注意updatedb的问题

     updatedb的进程在运行时,会非常多的占用系统资源

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

(0)
黑白子黑白子
上一篇 2016-04-05
下一篇 2016-04-05

相关推荐

  • 文件相关操作练习

    1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限: 2、编辑/etc/group文件,添加组hadoop: 3、手动编辑/etc/passwd文件新增一行,添加用户hadoop,其基本组ID为hadoop组的id号;其家目录为/home/hadoop: 4、复制/etc/sk…

    2017-11-17
  • sed行编辑器

    Linux文本处理三剑客之一:sed(Stream Editor)流编辑器 sed:     将指定的文本文件内容逐行读取至sed的临时内存空间当中,称为"模式空间",而后逐行查看是否被sed的地址定界所匹配到,如果匹配,则执行相应的编辑操作,否则,默认将模式空间中的内容打印至标准输出  …

    Linux干货 2016-08-15
  • N25-第三周作业

    一、列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可.          [root@test ~]# who | cut -d' ' -f1 | sort -u 二、取出最后登录到当前系统的用户的相关信息。    &nbs…

    Linux干货 2016-12-26
  • OpenSSL 及创建私有CA

    OpenSSL 及创建私有CA OpenSSL OpenSSL,是一个开放源代码的软件库包,应用程序可以使用这个包来进行安全通信,避免窃听,同时确认另一端连接者的身份。这个包广泛被应用在互联网的网页服务器上。 接下来对openssl基本命令进行介绍openssl 非常强大其子命令很多,这里只是对完成某些操作进行部分解释openssl 的基本格式为openss…

    2017-09-11
  • grep简述

    grep(Globel Search Regular Expression and Printing out the line) 它能使用正则表达式搜索文本,并把匹配的行打印出来。 grep包括grep、egrep和fgrep。 egrep表示扩展的grep,相比grep支持更多的匹配模式, “grep -E”相当于egrep。 fgrep是fast gre…

    2017-04-06
  • N23-第一周 记流水账

      机器已经设置好了  屏幕左边是linux控制台,屏幕中间放置记事本来记笔记,屏幕右边是教学视频,如图 费我老大劲 笔记本的无线网卡驱动不好弄啊   注重操作实践,全程跟着操作,一定要照着做,动手啊动手…………..前十五天内容以查漏补缺为主,所以笔记是兴之所至,遵循以下原则:&n…

    Linux干货 2016-09-18

评论列表(1条)

  • stanley
    stanley 2016-04-05 22:43

    写标签是个好习惯,markdown可多参考顶置文章