linux命令: 两个查找工具 locate,find
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 用于产生某个命令的参数,
linux命令: 两个查找工具 locate,find的更多相关文章
- linux 两个查找工具 locate,find详解
linux 中有很多查找工具,今天主要讲解locate,find两个工具. 1.locate (1)查询系统上预建的文件索引数据库 /var/lib/mlocate/mlocate.db 注意:如果这 ...
- linux 两个查找工具 locate,find
linux 中有很多查找工具,今天主要讲解locate,find两个工具. 一.locate 1.性能介绍 查询系统上预建的文件索引数据库 /var/lib/mlocate/mlocate.db 注意 ...
- Linux操作系统的文件查找工具locate和find命令常用参数介绍
Linux操作系统的文件查找工具locate和find命令常用参数介绍 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.非实时查找(数据库查找)locate工具 locate命 ...
- Linux上的文件查找工具之locate与find
前言 Linux上提供了两款工具用于查找文件,一款是locate,另一款是find. locate的特点是根据已生成的数据库查找,速度较快,但是查找的是快照数据,不准确. 因此在日常使用中,为了准确性 ...
- Linux查找工具locate和find
linux 中有很多查找工具,今天主要讲解locate,find两个工具. 一.locate 1.性能介绍 非实时查找(数据库查找):locate 查询系统上预建的文件索引数据库 /var/lib/m ...
- linux文件查找工具——locate,find
一文件查找介绍 文件的查找就是在文件系统上查找符合条件的文件. 文件查找的方式:locate, find非实时查找也就是基于数据库查找的locate,效率特别高. 实时查找:find 二locate ...
- linux命令总结之查找命令find、locate、whereis、which、type
我们经常需要在系统中查找一个文件,那么在Linux系统中我们如何准确高效的确定一个文件在系统中的具体位置呢?一下我总结了在linux系统中用于查找文件的几个命令. 1.find命令 find是最常用也 ...
- Linux命令-下载文件的工具:wget
Linux系统中的wget是一个下载文件的工具,它用在命令行下.对于Linux用户是必不可少的工具,我们经常要下载一些软件或从远程服务器恢复备份到本地服务器.wget支持HTTP,HTTPS和FTP协 ...
- linux命令 iperf-网络性能测试工具
博主推荐:更多网络测试相关命令关注 网络测试 收藏linux命令大全 iperf命令是一个网络性能测试工具.iperf可以测试TCP和UDP带宽质量.iperf可以测量最大TCP带宽,具有多种参数和 ...
随机推荐
- maven error: element dependency can not have character children
就是Mavn pom.xml的解析错误,因为dependency这个标签中有不可见的垃圾字符,解决方法就是删掉重新打字进去就可以了. references: https://stackoverflow ...
- JAVA方法中的参数用final来修饰的原因
JAVA方法中的参数用final来修饰的原因 很多人都说在JAVA中用final来修饰方法参数的原因是防止方法参数在调用时被篡改,其实也就是这个原因,但理解起来可能会有歧义,有的人认为是调用语句的 ...
- Future、FutureTask实现原理浅析(源码解读)
前言 最近一直在看JUC下面的一些东西,发现很多东西都是以前用过,但是真是到原理层面自己还是很欠缺. 刚好趁这段时间不太忙,回来了便一点点学习总结. 前言 最近一直在看JUC下面的一些东西,发现很多东 ...
- Atitit mysql 存储过程捕获所有异常,以及日志记录异常信息
Atitit mysql 存储过程捕获所有异常,以及日志记录异常信息 1.1. 异常的处理模式exit continue undo模式 1 1.2. 捕获所有异常使用 DECLARE ...
- vue及ElementUI环境搭建
1. nodejs安装及npm安装 下载地址:https://nodejs.org/en/download/ 选择windows Installer 下载完成后 运行node-v8.11.1-x64. ...
- cx_oracle访问处理oracle中文乱码问题
cx_oracle访问处理oracle中文乱码问题 问题描述 使用docker打包了centos镜像,编码为gbk,随后访问oracle出现了很多乱码.其原因自然是因为编码不一致,服务器为zhs16g ...
- (转)创建Windows服务(Windows Services)N种方式总结
转自:http://www.cnblogs.com/aierong/archive/2012/05/28/2521409.html 最近由于工作需要,写了一些windows服务程序,有一些经验,我现在 ...
- 建站工具Hexo
$ npm install hexo-cli -g $ hexo init blog $ cd blog $ npm install $ hexo server
- 基数计数——HyperLogLog
所谓的基数计数就是统计一组元素中不重复的元素的个数.如统计某个网站的UV,或者用户搜索网站的关键词数量:再如对一个网站分别统计了三天的UV,现在需要知道这三天的UV总量是多少,怎么融合多个统计值. 1 ...
- 2.静态AOP实现-装饰器模式
通过装饰器模式实现在RegUser()方法本身业务前后加上一些自己的功能,如:BeforeProceed和AfterProceed,即不修改UserProcessor类又能增加新功能 定义1个用户接口 ...