【Linux】Linux查找功能

     linux系统中我们经常会需要查找某些文件,当有时候我们不确定一个文件的位置,比如某服务配置文件具体路径,自己没有头绪去寻找的话会很难找,也会耽误时间。linux就提供了很多命令,find,locate,which,whereis等。下面就详细介绍这些命令并使用。

 

 find命令


 find命令是linux中最常见的查找文件的命令,功能很强大,它是用来在指定目录下查找文件。任何位于参数之前的字符串都将被视为欲查找的目录名。如果使用该命令时,不设置任何参数,则find命令将在当前目录下查找子目录与文件。并且将查找到的子目录和文件全部进行显示。

   语法:

          find (选项) (参数)  [filename]

   

示例:

搜索当前目录(包含子目录下所有文件和文件夹)。

[root@localhost /]# find .

搜索某个目录下的所有子目录和文件。

[root@localhost /]# find /home   这里会把home下所有子目录文件都显示出来

搜索某个目录下的某个文件,这里加上参数-name 就是代表搜索文件名称。

[root@localhost /]# find /home  -name "123.txt"
/home/test123/abc/123.txt

对搜索目录的深度限制,-maxdepth参数是对搜索深度的设置

[root@localhost /]# find . -maxdepth 1   1就是搜索一层 
.
./boot
./dev
./home
./proc
./run
./sys
./etc
./root
./tmp

对文件类型的搜索,参数type  

[root@localhost /]# find . -maxdepth 1 -type f      f代表搜索文件
./.autorelabel
./appendonly.aof
./dump.rdb
[root@localhost /]# find . -maxdepth 1 -type d      d代表搜索的是目录
.
./boot
./dev
./home
./proc

上面搜索出来的文件目录都仅仅只显示名字,想看到详细信息

[root@localhost /]# find . -maxdepth 1 -type f -exec ls -lh {} \;
-rw-r--r-- 1 root root 0 6月  28 2017 ./.autorelabel
-rw-r--r-- 1 root root 30M 9月  14 2017 ./appendonly.aof
-rw-r--r-- 1 root root 4.5K 9月  14 2017 ./dump.rdb

按照文件或目录的权限搜索。需要 find命令中 perm 参数。使用方法可以参考这篇 https://blog.csdn.net/lidonghat/article/details/66478071

[root@localhost /]# find . -maxdepth 1 -type d -perm -755  -exec ls -dhl  {} \;  按权限搜索当前目录中的目录
drwxr-xr-x 20 root root 3.3K 5月   6 13:02 ./dev
drwxr-xr-x. 9 root root 87 5月   5 11:34 ./home
drwxr-xr-x 35 root root 1020 5月   6 13:08 ./run
drwxr-xr-x. 145 root root 8.0K 5月   6 13:03 ./etc
drwxrwxrwt. 28 root root 8.0K 5月   6 15:55 ./tmp
drwxr-xr-x. 24 root root 4.0K 5月   6 13:02 ./var
drwxr-xr-x. 13 root root 4.0K 6月  27 2017 ./usr
drwxr-xr-x. 2 root root 6 6月  10 2014 ./media
drwxrwxrwx. 4 root root 27 12月 15 17:25 ./mnt
drwxr-xr-x. 14 root root 4.0K 10月 13 2017 ./opt
drwxr-xr-x. 2 root root 6 6月  10 2014 ./srv

 

[root@localhost /]# find . -maxdepth 1 -type f -perm 644  -exec ls -hl  {} \;  按权限搜索当前目录中的文件
-rw-r--r-- 1 root root 0 6月  28 2017 ./.autorelabel
-rw-r--r-- 1 root root 30M 9月  14 2017 ./appendonly.aof
-rw-r--r-- 1 root root 4.5K 9月  14 2017 ./dump.rdb

 找到当前目录下权限不是644的文件,-perm参数前面加了一个感叹号,取反

[root@localhost /]# find . -maxdepth 1 -type f ! -perm  644  -exec ls -hl  {} \;
-rwxr-xr-x 1 root root 0 5月   6 16:06 ./zzz

模糊搜索文件后缀包含.bash的文件

[root@localhost /]# find /home  -name "*.bash*"
/home/xyy/.bash_logout
/home/xyy/.bash_profile
/home/xyy/.bashrc
/home/xyy/.bash_history
/home/mysql/.bash_logout

 模糊搜索文件后缀不包含.bash的文件

[root@localhost /]# find /home ! -name "*.bash*"

搜索当前目录属于root用户的文件

[root@localhost /]# find . -maxdepth 1 -type f -user root  -exec ls -hl  {} \;
-rw-r--r-- 1 root root 0 6月  28 2017 ./.autorelabel
-rw-r--r-- 1 root root 30M 9月  14 2017 ./appendonly.aof
-rw-r--r-- 1 root root 4.5K 9月  14 2017 ./dump.rdb
-rwxr-xr-x 1 root root 0 5月   6 16:06 ./zzz

 搜索文件大小大于300m的文件

[root@localhost ~]# find / -type f -size +300M
/proc/kcore
find: ‘/proc/6258/task/6258/fdinfo/6’: 没有那个文件或目录
find: ‘/proc/6258/fdinfo/6’: 没有那个文件或目录
/usr/local/mysql/lib/libmysqld.a
/usr/local/mysql/bin/mysqld

命令执行结果中有一些提示信息,这些信息不需要显示,可以去除。

[root@localhost ~]# find / -type f -size +300M 2>/dev/null
/proc/kcore
/usr/local/mysql/lib/libmysqld.a
/usr/local/mysql/bin/mysqld
/usr/local/mysql/bin/mysql_embedded
/usr/local/mysql/bin/mysqltest_embedded
/usr/local/mysql/bin/mysql_client_test_embedded

知道每个文件具体大小,后面加上使用du命令统计下。

[root@localhost ~]# find / -type f -size +300M 2>/dev/null | xargs du -sh
0       /proc/kcore
928M    /usr/local/mysql/lib/libmysqld.a
350M    /usr/local/mysql/bin/mysqld
330M    /usr/local/mysql/bin/mysql_embedded
329M    /usr/local/mysql/bin/mysqltest_embedded
331M    /usr/local/mysql/bin/mysql_client_test_embedded
396M    /usr/local/mysql/data/oa_workflow/OPERATION_LOGS.ibd
713M    /usr/local/mysql/data/db_kingnet_oa/t_message.ibd

对结果的文件大小排序。

[root@localhost ~]# find / -type f -size +300M 2>/dev/null | xargs du -sh | sort -nr
928M    /usr/local/mysql/lib/libmysqld.a
928M    /opt/mysql-8.0.0-dmr/libmysqld/libmysqld.a
713M    /usr/local/mysql/data/db_kingnet_oa/t_message.ibd
665M    /opt/mysql-8.0.0-dmr/sql/libsql.a
643M    /opt/mysql-8.0.0-dmr/libmysqld/libsql_embedded.a
488M    /usr/local/mysql/data/oa_2018/operation_logs.ibd
396M    /usr/local/mysql/data/oa_workflow/OPERATION_LOGS.ibd
364M    /usr/local/mysql/data/oa_workflow_test/OPERATION_LOGS.ibd
350M    /usr/local/mysql/bin/mysqld
350M    /opt/mysql-8.0.0-dmr/sql/mysqld

计算当前目录中文件md5的值并保存在文件中

[root@localhost oa]# find . -type f | xargs  md5sum  > md5.txt
[root@localhost oa]# cat md5.txt
cfa55387ce15a2fb9060dd448d88538f  ./time.sh
f107df99a0e3d3f3a1bb6abaa549e5d8  ./a.txt
707cce2673010a0d0191c4a2d2440580  ./.a.txt.swp
37c218cf1dcb7cdb3a483eb7b8244246  ./passwd
d41d8cd98f00b204e9800998ecf8427e  ./b.txt
98828b6f94757a6bdfdeb0ff6decaa7d  ./md5.txt

 

结合-exec和xargs 选项来搜索出来find出来的结果。(xargs与管道的区别是:管道是将前面命令的标准输出作为后面的标准输入,而xargs是实现“将标准输入作为命令的参数”

exec后面跟着要执行的命令。

[root@localhost oa]# ll
总用量 16
-rw-r--r-- 1 root root   26 5月   6 16:25 a.txt
-rw-r--r-- 1 root root    0 5月   6 13:38 b.txt
-rw-r--r-- 1 root root  262 5月   6 18:08 md5.txt
-rw-r--r-- 1 root root 2581 5月   4 13:47 passwd
-rw-r--r-- 1 root root   30 4月  27 22:51 time.sh
[root@localhost oa]# find . -type f -exec chmod 777 {} \;      将搜索出来的文件权限改成777, 使用exec参数后面要固定跟上 {} \;
[root@localhost oa]# ll
总用量 16
-rwxrwxrwx 1 root root   26 5月   6 16:25 a.txt
-rwxrwxrwx 1 root root    0 5月   6 13:38 b.txt
-rwxrwxrwx 1 root root  262 5月   6 18:08 md5.txt
-rwxrwxrwx 1 root root 2581 5月   4 13:47 passwd
-rwxrwxrwx 1 root root   30 4月  27 22:51 time.sh

还有个参数和exec功能一样,只不过每个具体执行的过程会提示是否同意。

[root@localhost oa]# find . -type f -ok chmod 777 {} \;
< chmod ... ./time.sh > ? y
< chmod ... ./a.txt > ? y
< chmod ... ./.a.txt.swp > ? y
< chmod ... ./passwd > ? y
< chmod ... ./b.txt > ? y
< chmod ... ./md5.txt > ? y

 

用xargs显示出每个文件的信息。

[root@localhost oa]# find . -type f | xargs stat
  文件:"./time.sh"
  大小:30              块:8          IO 块:4096   普通文件
设备:fd00h/64768d      Inode:1176906     硬链接:1
权限:(0777/-rwxrwxrwx)  Uid:(    0/    root)   Gid:(    0/    root)
最近访问:2018-05-06 18:07:52.548866071 +0800
最近更改:2018-04-27 22:51:34.869883350 +0800
最近改动:2018-05-06 20:53:43.855914501 +0800
创建时间:-
  文件:"./a.txt"
  大小:26              块:8          IO 块:4096   普通文件
设备:fd00h/64768d      Inode:1176944     硬链接:1
权限:(0777/-rwxrwxrwx)  Uid:(    0/    root)   Gid:(    0/    root)
最近访问:2018-05-06 16:25:33.041110933 +0800
最近更改:2018-05-06 16:25:29.743048457 +0800
最近改动:2018-05-06 20:53:43.858914559 +0800
........

 找出 / 目录下以 .ini结尾的文件,并进行文件分类

[root@localhost pcntl]# find / -name *.ini -type f -print | xargs file
/etc/php.d/curl.ini:                                                              ASCII text
/etc/php.d/posix.ini:                                                             ASCII text
/etc/php.d/phar.ini:                                                              ASCII text
/etc/php.d/zip.ini:                                                               ASCII text
/etc/php.d/sysvsem.ini:                                                           ASCII text
/etc/php.d/sysvshm.ini:                                                           ASCII text
/etc/php.d/json.ini:                                                              ASCII text
/etc/php.d/sysvmsg.ini:                                                           ASCII text
/etc/php.d/fileinfo.ini:                                                          ASCII text
/etc/php.ini:                                                                     ASCII English text
/opt/baletu/jdk1.8.0_51/lib/missioncontrol/configuration/config.ini:              ASCII text
/opt/baletu/jdk1.8.0_51/bin/jmc.ini:                                              ASCII text
/alidata/www/baletoo/Issue/conf/application.ini:                                  ASCII text, with CRLF line terminators
/alidata/www/baletoo/m/YafMobile/conf/application.ini:                            ASCII text, with CRLF line terminators
/alidata/www/baletoo/YafPc/conf/application.ini:                                  ASCII text, with CRLF line terminators

 

find功能还有很多,这里暂时就介绍这么多。

  

whereis命令


 whereis命令用来搜索出二进制程序、源代码文件和man手册页等相关文件的路径。它的搜索内容比较局限,只能用于程序名的搜索,而且只搜索二进制文件(参数-b)、man说明文件(参数-m)和源代码文件(参数-s)。如果省略参数,则返回所有信息。

示例:

[root@localhost oa]# whereis mysql
mysql: /usr/lib64/mysql /usr/local/mysql /usr/share/mysql /usr/local/mysql/bin/mysql

 

搜索二进制文件

[root@localhost oa]# whereis -b ls
ls: /usr/bin/ls

  

 which命令


 which命令用于查找并显示给定命令的绝对路径,环境变量PATH中保存了查找命令时需要遍历的目录。which指令会在环境变量$PATH设置的目录里查找符合条件的文件。也就是说,使用which命令,就可以看到某个系统命令是否存在,以及执行的到底是哪一个位置的命令。which是根据使用者所配置的$PATH 变量内的目录去搜寻可运行档的!所以不同的$PATH 配置内容所找到的内容不一样。

示例:

[root@localhost oa]# which php
/usr/local/php7/bin/php

 

locate命令


locate命令用来查找文件或目录,它和find功能差不多,只不过比find命令块很多,因为find是在系统中每个目录搜索,而locate是搜索linux中的一个数据库。

示例:

[root@localhost tmp]# locate nginx.conf
/opt/nginx-1.12.0/conf/nginx.conf
/usr/local/nginx/conf/.nginx.conf.swp
/usr/local/nginx/conf/nginx.conf
/usr/local/nginx/conf/nginx.conf.def
[root@localhost tmp]# touch nginx.conf
[root@localhost tmp]# locate nginx.conf
/opt/nginx-1.12.0/conf/nginx.conf
/usr/local/nginx/conf/.nginx.conf.swp
/usr/local/nginx/conf/nginx.conf
/usr/local/nginx/conf/nginx.conf.default
/var/lib/pcp/pmdas/nginx/nginx.conf

    locate这个命令不是搜索整个文件系统,而是搜索一个数据库,所以搜索速度很快。Linux系统自动创建这个数据库,并且每天自动更新一次,所以使用locate命令查不到最新变动过的文件。为了避免这种情况,可以在使用locate之前,先使用updatedb命令手动更新数据库。

-v:显示执行的详细过程
[root@localhost ~]# touch song.php
[root@localhost ~]# locate song.php
/root/song.php

在tmp目录下不行

posted @ 2018-05-05 20:39  songguojun  阅读(22558)  评论(0编辑  收藏  举报