linux 中有很多查找工具,今天主要讲解locate,find两个工具。

1.locate

(1)查询系统上预建的文件索引数据库

/var/lib/mlocate/mlocate.db

注意:如果这个文件删除了,locate就无法使用了。需手动手动更新数据库(updatedb),或重启系统,locate才能恢复作用

依赖于事先构建的索引:

索引的构建是在系统较为空闲时自动进行( 周期性任务 /etc/cron.daily), 管理员手动更新数据库(updatedb)

索引构建过程需要遍历整个根文件系统,极消耗资源

(2)工作特点:

•  查找速度快

•  模糊查找

•  非实时查找

•  搜索的是文件的全路径,不仅仅是文件名

•  只搜索用户具备读取和执行权限的目录,没有权限,即使数据库有内容,也不显示,为了安全

(3)locate   用法

-i     不区分大小写的搜索

-n #  只列举前#个匹配项目

-r  支持正则

2.find

实时查找工具,通过遍历指定路径完成文件查找(find不同于其他命令的习惯,选项只加一个-)

相较于locate,find功能非常强大,除了基于文件名字查找外,还能基于权限,文件类型,大小等好多方式进行查找,所以被我们普遍应用。

(1)工作特点:

• 查找速度略慢

• 精确查找(可以通过正则,通配符,实现模糊查询)

• 实时查找

• 只搜索用户具备读取和执行权限的目录

(2)find 用法格式

find [OPTION]... [ 查找路径] [ 查找条件] [ 处理动作]

查找路径:指定具体目标路径;默认为当前目录

查找条件:指定的查找标准,可以文件名、大小、类型、权限等标准进行;默认为找出指定路径下的所有文件

处理动作:对符合条件的文件做操作,默认输出至屏幕,还有更多其他的处理动作。

 (3)查找条件

① 根据搜索层级

-maxdepth level  最搜索目录深度,  -1 指定目录为第1级,当前目录

-mindepth level   最搜索目录深度

② 根据文件名和inode 查找:

-name   :基于名称的精确查找 ,支持使用文字通配符 *, ?, [], [^]等

-iname  :基于名称忽略大小写的精确查找查找

-inum    :基于inode查找

-samefile name :基于相同inode的查找(查找硬链接)

-links n  硬链接数为n 的文件

-regex "PATTERN" :支持正则 ,默认为(emacs标准的正则),查询正则表达的范围

例:".*\/[a-z].*" 搜索所有以小写字母开头的文件

-regextype egrep -regex 支持egrep同标准的正则

 根据属主、属组查找:

-user USERNAME :查找属主为指定用户(UID) 的文件

-group GRPNAME:  查找属组为指定组(GID) 的文件

-uid UserID :查找属主为指定的UID 号的文件

-gid GroupID :查找属组为指定的GID 号的文件

-nouser :查找没有属主的文件

-nogroup :查找没有属组的文件

④ 根据文件类型查找:

find -type

f:  普通文件

d:  目录文件

l:  符号链接文件 (软连接)

s :套接字文件 (/dev/log)

b:  块设备文件 (/dev/sda)

c:  字符设备文件 (/dev/tty)

p:  管道文件

⑤  根据文件大小来查找:

find -size [+|-]#UNIT 根据文件大小来查找     常用单位:k, M, G,c(byte)

          #UNIT: (#-1, #]         如:6k 表示(5k,6k]

           -#UNIT:[0,#-1]  如:-6k 表示[0,5k]

+#UNIT:(#,∞)  如:+6k 表示(6k,∞)

⑥ 根据时间戳:

以“天”为单位:

-atime [+|-]#, (访问时间)

#: [#,#+1) 如:3  表示[3,4)

+#: [#+1,∞] 如:+3表示[4,∞)

-#[0,#) 如:-3 表示[0,3)

-mtime (修改时间)用法同上

-ctime(元数据改变时间)用法同上

以“分钟”为单位: (用法同上)

-amin     -mmin      -cmin

⑦ -perm  根据权限查找:

mode:精确权限匹配

+mode[/mode] 任何一类(u,g,o)对象的权限中只要能一位匹配即可,或关系从centos7开始淘汰

-mode   每一类对象都必须同时拥有指定权限,与关系

0 表示不关注

⑧ 组合条件查找:

与:-a  可省略    例:find -nouser [-a] -nogroup

或:-o

非:-not, !

德· 摩根定律:

(非 A) 或 (非 B) =  非(A 且 B)           !A -o !B = !(A -a B)

(非 A) 且 (非 B) =  非(A 或 B)           !A -a !B = !(A -o B)

(4)处理动作

-print 默认

-delete 直接删除所查找到的文件,不询问。

-ls 长列出所查找到的文件,和ls -li 相似

-fls file 将查找到的文件长列出导入到指定文件。

 > file 将查询结果导入file       >> file 将查询结果追加入file

-ok command \;   对查找到的文件当做下一命令的参数去执行(交互式)(不要忘记最后的 \; 是固定格式)

-exec command \; 对查找到的文件当做下一命令的参数去执行(非交互式

{ }:  用于引用查找到的文件名称自身

(5)参数替换 xargs(“万能”的参数传递)

xargs  用于产生某个命令的参数,

用途:很多命令不支持管道| 来传递参数,xargs 命令能传递所有参数
                 例如:find /etc/ -name "*.sh" | xargs ls -l
          有些命令不能接受过多参数 ,命令执行可能会失败,xargs可解决
                 例如:touch , rm 不能一次执行超过一定的参数(大概30000)
                           可以 echo {1..30000} | xargs touch

linux命令: 两个查找工具 locate,find的更多相关文章

  1. linux 两个查找工具 locate,find详解

    linux 中有很多查找工具,今天主要讲解locate,find两个工具. 1.locate (1)查询系统上预建的文件索引数据库 /var/lib/mlocate/mlocate.db 注意:如果这 ...

  2. linux 两个查找工具 locate,find

    linux 中有很多查找工具,今天主要讲解locate,find两个工具. 一.locate 1.性能介绍 查询系统上预建的文件索引数据库 /var/lib/mlocate/mlocate.db 注意 ...

  3. Linux操作系统的文件查找工具locate和find命令常用参数介绍

    Linux操作系统的文件查找工具locate和find命令常用参数介绍 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.非实时查找(数据库查找)locate工具  locate命 ...

  4. Linux上的文件查找工具之locate与find

    前言 Linux上提供了两款工具用于查找文件,一款是locate,另一款是find. locate的特点是根据已生成的数据库查找,速度较快,但是查找的是快照数据,不准确. 因此在日常使用中,为了准确性 ...

  5. Linux查找工具locate和find

    linux 中有很多查找工具,今天主要讲解locate,find两个工具. 一.locate 1.性能介绍 非实时查找(数据库查找):locate 查询系统上预建的文件索引数据库 /var/lib/m ...

  6. linux文件查找工具——locate,find

    一文件查找介绍 文件的查找就是在文件系统上查找符合条件的文件. 文件查找的方式:locate, find非实时查找也就是基于数据库查找的locate,效率特别高. 实时查找:find 二locate ...

  7. linux命令总结之查找命令find、locate、whereis、which、type

    我们经常需要在系统中查找一个文件,那么在Linux系统中我们如何准确高效的确定一个文件在系统中的具体位置呢?一下我总结了在linux系统中用于查找文件的几个命令. 1.find命令 find是最常用也 ...

  8. Linux命令-下载文件的工具:wget

    Linux系统中的wget是一个下载文件的工具,它用在命令行下.对于Linux用户是必不可少的工具,我们经常要下载一些软件或从远程服务器恢复备份到本地服务器.wget支持HTTP,HTTPS和FTP协 ...

  9. linux命令 iperf-网络性能测试工具

    博主推荐:更多网络测试相关命令关注 网络测试  收藏linux命令大全 iperf命令是一个网络性能测试工具.iperf可以测试TCP和UDP带宽质量.iperf可以测量最大TCP带宽,具有多种参数和 ...

随机推荐

  1. maven error: element dependency can not have character children

    就是Mavn pom.xml的解析错误,因为dependency这个标签中有不可见的垃圾字符,解决方法就是删掉重新打字进去就可以了. references: https://stackoverflow ...

  2. JAVA方法中的参数用final来修饰的原因

    JAVA方法中的参数用final来修饰的原因   很多人都说在JAVA中用final来修饰方法参数的原因是防止方法参数在调用时被篡改,其实也就是这个原因,但理解起来可能会有歧义,有的人认为是调用语句的 ...

  3. Future、FutureTask实现原理浅析(源码解读)

    前言 最近一直在看JUC下面的一些东西,发现很多东西都是以前用过,但是真是到原理层面自己还是很欠缺. 刚好趁这段时间不太忙,回来了便一点点学习总结. 前言 最近一直在看JUC下面的一些东西,发现很多东 ...

  4. Atitit mysql 存储过程捕获所有异常,以及日志记录异常信息

    Atitit mysql 存储过程捕获所有异常,以及日志记录异常信息 1.1. 异常的处理模式exit  continue undo模式 1 1.2. 捕获所有异常使用        DECLARE ...

  5. vue及ElementUI环境搭建

    1. nodejs安装及npm安装 下载地址:https://nodejs.org/en/download/ 选择windows Installer 下载完成后 运行node-v8.11.1-x64. ...

  6. cx_oracle访问处理oracle中文乱码问题

    cx_oracle访问处理oracle中文乱码问题 问题描述 使用docker打包了centos镜像,编码为gbk,随后访问oracle出现了很多乱码.其原因自然是因为编码不一致,服务器为zhs16g ...

  7. (转)创建Windows服务(Windows Services)N种方式总结

    转自:http://www.cnblogs.com/aierong/archive/2012/05/28/2521409.html 最近由于工作需要,写了一些windows服务程序,有一些经验,我现在 ...

  8. 建站工具Hexo

    $ npm install hexo-cli -g $ hexo init blog $ cd blog $ npm install $ hexo server

  9. 基数计数——HyperLogLog

    所谓的基数计数就是统计一组元素中不重复的元素的个数.如统计某个网站的UV,或者用户搜索网站的关键词数量:再如对一个网站分别统计了三天的UV,现在需要知道这三天的UV总量是多少,怎么融合多个统计值. 1 ...

  10. 2.静态AOP实现-装饰器模式

    通过装饰器模式实现在RegUser()方法本身业务前后加上一些自己的功能,如:BeforeProceed和AfterProceed,即不修改UserProcessor类又能增加新功能 定义1个用户接口 ...