文件查找相关: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 22:41
下一篇 2016-04-05 22:46

相关推荐

  • N25第六周作业

    vim编辑器 基本模式: 编辑模式,命令模式 输入模式 末行模式: 内置的命令行接口;   打开文件: # vim [options] [file ..] +#:打开文件后,直接让光标处于第#行的行首; +/PATTERN:打开文件后,直接让光标处于第一个被PATTERN匹配到的行的行首;   模式转换: 编辑模式:默认模式 编辑模式 &…

    Linux干货 2017-02-15
  • OpenSSH的应用和利用OpenSSL创建私有CA签证给httpd服务器开起https

    一、OpenSSH     OpenSSH与SSH协议是远程登录的首选连接工具。它加密所有流量,以消除窃听,连接劫持和其它攻击。OpenSSH常常被误认以为与OpenSSL有关系,但实际上这两个项目的有不同的目的,不同的发展团队,名称相近只是因为两者有同样的软件发展目标──提供开放源代码的加密通讯软件。  &…

    Linux干货 2016-04-24
  • 优云老王(四)干货总结:数据带来的奇妙世界

    作为产品经理的我们,不仅仅需要业务敏感的直觉,还需要数据驱动我们的产品不断创新!关于如何看数据,我列了主要的四个场景。 场景一:看页面点击,了解用户关注什么,卡在哪里 给谁看:产品经理和交互设计师 看什么: 由于我们对Web应用的所有界面,可交互元素都做了埋点,那么我们就可以看用户在页面里都做了哪些点击动作。首先是整个页面的横向比较,每个页面本身的操作数(重…

    2016-09-19
  • 在VMware workstations中安装CentOS-7-x86_64-Everything-1611.ISO

      对于最近在Linux学习的过程中,许多同学对CentOS系统的详细配置还不熟悉,于是我编写此详细步骤供大家参考。 工具: VMware workstations; CentOS-7-x86_64-Everything-1611.iso; 准备工作:  1、先要下载一个系统镜像centOS-7-x86_64-Everythin…

    2017-07-11
  • 小东北Eric的学习宣言

      大家好,我是网络班24期新加入的学员,之前工作了几年,一直没有找到一个很明确的工作方向,现在终于可以有一个很明确的努力方向啦,那就是跟着马哥,成为技术大牛,听马哥说过,键盘敲烂,月薪两万,为了这个目标,并且努力超越它,加油!冲!冲!冲!

    Linux干货 2016-10-19
  • 源码包编译安装MariaDB-10.1.22

    源码包编译安装MariaDB-10.1.22 1、获取源码包        mariadb-10.1.22.tar.gz 2、编译环境及依赖关系     yum groupinstall -y Development Tools yum -y install …

    Linux干货 2017-03-16

评论列表(1条)

  • stanley
    stanley 2016-04-05 22:43

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