【Linux】Linux查找功能

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

 

 find命令node


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

   语法:linux

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

   

示例:sql

搜索当前目录(包含子目录下全部文件和文件夹)。数据库

[root@localhost /]# find .

搜索某个目录下的全部子目录和文件。json

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

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

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

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

[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目录下不行