linux中查找命令之find、locate、whereis、which、type

1.find

    find是最常见和最强大的查找命令,你可以用它找到任何你想找的文件。与查询数据库(/var/lib/locatedb)文件不同,find查找磁盘空间

1.1 find的使用格式如下:

  $ find <指定目录> <指定条件> <指定动作>

  - <指定目录>: 所要搜索的目录及其所有子目录。默认为当前目录。

  - <指定条件>: 所要搜索的文件的特征。

  - <指定动作>: 对搜索结果进行特定的处理。

    如果什么参数也不加,find默认搜索当前目录及其子目录,并且不过滤任何结果(也就是返回所有文件),将它们全都显示在屏幕上。

1.2 使用实例:

示例1: find . -name 'druid'

        搜索当前目录(含子目录,以下同)中,所有文件名以druid的文件。

[root@emr-header-1 druid]# find . -name 'druid'
./0.12.0-1.0.1/package/druid-0.12.0-1.0.1/var/druid
./0.12.0-1.0.1/package/druid-0.12.0-1.0.1/conf/druid
./0.12.0-1.0.1/package/druid-0.12.0-1.0.1/conf-quickstart/druid

示例2:$ find . -name 'my*' -ls  搜索当前目录中,所有文件名以druid的文件,并显示它们的详细信息。


[root@emr-header-1 druid]# find . -name 'my*' -ls
533103    4 drwxr-xr-x   2 druid    hadoop       4096 Jul 11 17:48 ./0.12.0-1.0.1/package/druid-0.12.0-1.0.1/extensions/mysql-metadata-storage
533311  964 -rw-r--r--   1 druid    hadoop     983911 Nov 30  2017 ./0.12.0-1.0.1/package/druid-0.12.0-1.0.1/extensions/mysql-metadata-storage/mysql-connector-java-5.1.38.jar
533312   12 -rw-r--r--   1 druid    hadoop      10478 Jun 26  2018 ./0.12.0-1.0.1/package/druid-0.12.0-1.0.1/extensions/mysql-metadata-storage/mysql-metadata-storage-0.12.0.jar

示例3: $ find . -type f -mmin -10

  搜索当前目录中,所有过去10分钟中更新过的普通文件。如果不加-type f参数,则搜索普通文件+特殊文件+目录。

[root@emr-header-1 druid]# find . -type f -mmin -10

示例4: find / -name druid    查询druid的所属路径

[root@emr-header-1 druid]# find / -name druid
/opt/apps/ecm/service/superset/0.28.1/package/superset-0.28.1/lib/python3.6/site-packages/superset/connectors/druid
/opt/apps/ecm/service/druid
/opt/apps/ecm/service/druid/0.12.0-1.0.1/package/druid-0.12.0-1.0.1/var/druid
/opt/apps/ecm/service/druid/0.12.0-1.0.1/package/druid-0.12.0-1.0.1/conf/druid
/opt/apps/ecm/service/druid/0.12.0-1.0.1/package/druid-0.12.0-1.0.1/conf-quickstart/druid
/opt/ecm/venv/lib/python2.7/site-packages/superset/connectors/druid
/var/spool/mail/druid
/var/lib/mysql/druid
/var/lib/ecm-agent/cache/ecm/service/DRUID/0.12.0.1.2/package/files/conf/druid
/var/lib/ecm-agent/cache/ecm-repo/druid
/etc/ecm/druid-conf-0.12.0-1.0.1/druid
/home/druid
/mnt/disk1/log/druid
/mnt/disk1/druid

 

2.locate

    locate(locate) 命令用来查找文件或目录。 locate命令要比find -name快得多,原因在于它不搜索具体目录,而是搜索一个数据库/var/lib/mlocate/mlocate.db 。这个数据库中含有本地所有文件信息。Linux系统自动创建这个数据库,并且每天自动更新一次,因此,我们在用whereis和locate 查找文件时,有时会找到已经被删除的数据,或者刚刚建立文件,却无法查找到,原因就是因为数据库文件没有被更新。为了避免这种情况,可以在使用locate之前,先使用updatedb命令,手动更新数据库。整个locate工作其实是由四部分组成的:

    /usr/bin/updatedb   主要用来更新数据库,通过crontab自动完成的

    /usr/bin/locate         查询文件位置

    /etc/updatedb.conf   updatedb的配置文件

    /var/lib/mlocate/mlocate.db  存放文件信息的文件

2.1 用法

    locate [OPTION]... [PATTERN]...

2.2 选项

  -b, --basename         match only the base name of path names
  -c, --count            只输出找到的数量
  -d, --database DBPATH  使用DBPATH指定的数据库,而不是默认数据库 /var/lib/mlocate/mlocate.db
  -e, --existing         only print entries for currently existing files
  -L, --follow           follow trailing symbolic links when checking file existence (default)
  -h, --help             显示帮助
  -i, --ignore-case      忽略大小写
  -l, --limit, -n LIMIT  limit output (or counting) to LIMIT entries
  -m, --mmap             ignored, for backward compatibility
  -P, --nofollow, -H     don't follow trailing symbolic links when checking file existence
  -0, --null             separate entries with NUL on output
  -S, --statistics       don't search for entries, print statistics about eachused database
  -q, --quiet            安静模式,不会显示任何错误讯息
  -r, --regexp REGEXP    使用基本正则表达式
      --regex            使用扩展正则表达式
  -s, --stdio            ignored, for backward compatibility
  -V, --version          显示版本信息
  -w, --wholename        match whole path name (default)

2.3 示例

示例1: 搜索etc目录下所有以my开头的文件

[root@cent6 lib]# locate /etc/my
/etc/my.cnf

示例2:新增的文件无法locate,使用updatedb

[root@cent6 ~]# touch new.txt
[root@cent6 ~]# locate new.txt
[root@cent6 ~]# updatedb
[root@cent6 ~]# locate new.txt
/root/new.txt

示例3:updatedb的配置文件/etc/updatedb.conf

[root@cent6 ~]# cat /etc/updatedb.conf 
PRUNE_BIND_MOUNTS = "yes"
PRUNEFS = "9p afs anon_inodefs auto autofs bdev binfmt_misc cgroup cifs coda configfs cpuset debugfs devpts ecryptfs exofs fuse fusectl gfs gfs2 hugetlbfs inotifyfs iso9660 jffs2 lustre mqueue ncpfs nfs nfs4 nfsd pipefs proc ramfs rootfs rpc_pipefs securityfs selinuxfs sfs sockfs sysfs tmpfs ubifs udf usbfs"
PRUNENAMES = ".git .hg .svn"
PRUNEPATHS = "/afs /media /net /sfs /tmp /udev /var/cache/ccache /var/spool/cups /var/spool/squid /var/tmp"

    第一行PRUNE_BIND_MOUNTS="yes"的意思是:是否进行限制搜索。

    第二行是排除检索的文件系统类型,即列出的文件系统类型不进行检索。

    第三行表示对哪些后缀的文件排除检索,也就是列在这里面的后缀的文件跳过不进行检索。不同后缀之间用空格隔开。

    第四行是排除检索的路径,即列出的路径下的文件和子文件夹均跳过不进行检索。updatedb之后使用locate仍然找不到想要文件可以检查挂载的目录是否被忽略了

 

3.whereis

    只能找二进制文件、可执行文件、帮助文档,源文件等,默认情况下只在某些目录下查找。

[root@emr-header-1 druid]# whereis hive
hive: /opt/apps/ecm/service/hive/2.3.3-1.0.1/package/apache-hive-2.3.3-1.0.1-bin/bin/hive

 

4.which

    which 查看可执行文件的位置,从全局环境变量PATH里面查找对应的路径,默认是找 bash内所规范的目录

[root@emr-header-1 druid]# which hive

/usr/lib/hive-current/bin/hive

 

5.type

    暂时本人没有用到,等用到的时候在看下吧。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序员学习圈

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值