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

一、locate

1、性能介绍

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

/var/lib/mlocate/mlocate.db

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

依赖于事先构建的索引:

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

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

2、工作特点

•  查找速度快

•  模糊查找

•  非实时查找

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

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

(3)locate   用法

-i     不区分大小写的搜索

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

-r  支持正则

二、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工具  locate命 ...

  3. linux命令: 两个查找工具 locate,find

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

  4. Linux查找工具locate和find

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

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

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

  6. linux下文件查找工具--find

    常用的文件查找命令有:which,locate,find 1.which命令 查找二进制数或二进制命令,由PATH给出 2.loacte 特点: 1.非实时,每天在系统上生成数据库,通过数据库查询 2 ...

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

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

  8. 【Linux相识相知】文件查找(locate/find)

    在用linux操作系统的时候,当我们忘记之前某个文件存储的位置,但是知道其文件名或者模糊的知道其文件名,我们都可以通过文件查找工具来查找,linux提供两种常用的查找工具,locate和find,在日 ...

  9. Linux文件查找工具之find “大宝剑”--转载

    原文地址:http://xinzong.blog.51cto.com/10018904/1749465 一.文件查找工具常用软件 locate: locate命令其实是find -name的另一种写法 ...

随机推荐

  1. html table 保存到excel中

    引用:HTML中的table导出为Excel文件 <!DOCTYPE html> <html lang="en"> <head> <met ...

  2. 20155205 郝博雅 Exp5 MSF基础应用

    20155205 郝博雅 Exp5 MSF基础应用 一.实验目标 本实践目标是掌握metasploit的基本应用方式,重点常用的三种攻击方式的思路.具体需要完成: 1.一个主动攻击实践,如ms08_0 ...

  3. Exp5 MSF基础运用 20154320 李超

    实验后回答问题 用自己的话解释什么是exploit,payload,encode. exploit:起运输的作用,将数据传输到对方主机. payload:其实就是指装载的“具体内容”.就相当于shel ...

  4. p112 the podocyte

    正常人尿液只有一很少的蛋白质.尿蛋白特别是白蛋白的出现,是肾小球疾病的重要特征,也是众多肾脏疾病的关键的诊断标记,包括了统计数据或者说经济效应上都很重要的那些肾病.糖尿病肾病等等.可能没被广泛认识的是 ...

  5. 运行纯PHP程序的时候,不应该加"?>"结束语

    运行纯PHP程序的时候,不应该加"?>"结束语 只有在和HTML混搭的时候再用?>结束语! 理由:可以让php脚本更安全的运行, 比如在脚本末尾注入换行.空格等字符,没 ...

  6. phantomjs的安装和使用链接

    1.先下载phantomjs并解压2.将phantomjs的bin目录配置到环境变量中3.测试phantomjs,cmd下输入phantomjs进入 (按 Ctrl + c 组 合键退出和 phant ...

  7. 转发: windows如何管理内存

    (1)有三种方法:虚拟内存,内存映射文件,内存堆栈. 虚拟内存是将页文件加载到内存,适用于比较大的对象或结构: 内存映射文件是将磁盘上文件加载到内存,适用于大文件和单机的进程间内存共享: 堆栈就是动态 ...

  8. cf Round#273 Div.2

    题目链接,点击一下 Round#273 Div.2 ================== problem A Initial Bet ================== 很简单,打了两三场的cf第一 ...

  9. [转] KVM storage performance and cache settings on Red Hat Enterprise Linux 6.2

    Almost one year ago, I checked how different cache settings affected KVM storage subsystem performan ...

  10. MySQL9:索引实战

    索引 无论是面试,还是实际工作中,对于一个Java程序员来说,数据库优化是避不开的一个技术点,关于数据库的优化,在性能达不到要求的情况下,我大致给出以下几个方向: (1)优化表结构,对常用字段和非常用 ...