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
暂时本人没有用到,等用到的时候在看下吧。