网站首页 > 技术教程 正文
工欲善其事,必先利其器。本次主要讲解是Linux系统中的文件查找指令,Linux文件查找,是在文件系统上查找符合条件的过程,文件查找有两个:locate指令以及find指令:
Locate:非实时查找工具;依赖于事先构建的索引;索引的构建是在系统较为空闲时自动进行(周期性任务);手动更新此数据库(updatedb);查找速度快;模糊查找。
Find:实时查找,查找的速度略慢,非常精确的查找。
Find指令
find命令是Linux系统中用来进行文件搜索用的最多的命令,它的功能非常强大,可实时查找,查找的速度略慢,非常精确的查找。但还是尽量在范围内去执行搜索任务,毕竟搜索是很占用资源的。find命令查找格式如下:
find [OPTION]... [查找路径] [查找条件] [处理动作]
查找路径:默认为当前路径;
查找条件:指定的查找标准,可以根据文件名、大小、属主属组、类型等进行;默认为找出指定路径下的所有文件;
处理动作:对符合条件的文件做什么操作;默认为输出至屏幕;
常用参数:
-name //已文件名称查找,支持使用glob; |
-iname //文件名称查找,不区分字符大小写,支持使用glob。 |
-regex //“PATTERN”,已PATTERN匹配整个文件路径字符串,而不仅仅是文件名称。 |
-user //查找属主为指定用户的文件 |
-group //根据属组查找 |
-gid //查找文件的属组为指定的gid文件 |
-uid //查找文件的属主为指定的uid的文件 |
-nouser //查找没有属主的文件 |
-nogroup //查找没有属组的文件 |
根据文件类型进行查找参数:
-type //后面跟上指定类型
f:普通文件 |
d:目录 |
l:符号连接 |
b:块设备 |
c:字符设备 |
p:命名管道 |
s:套接字 |
组合查找条件:
与条件:-a |
或条件:-o |
非条件:-not,! |
根据文件大小来查找:
-size [+|-]#UNIT |
单位:k, M, G |
#UNIT: (#-1,#] |
-#UNIT:[0,#-1] |
根据时间戳以“天”为单位:
-atime [+|-]# |
#:[#,#+1) |
+#: [#+1,oo] |
-#: [0,#) |
-mtime |
-ctime |
以“分钟”为单位:
-amin |
-mmin |
-cmin |
根据权限:
-perm [/|-]MODE |
MODE: 精确权限匹配 |
/MODE:任何一类对象(u,g,o)的任何一位权限符合条件即可;隐含或条件; |
-MODE:为每一类对象指定的每一位权限都必须同时存在方为符合条件;隐含与条件; |
处理动作:
-print:默认处理动作 |
-ls:类似于对查找到的每个文件做"ls -l"的操作; |
-delete:删除查找到的文件; |
-fls/path/to/somefile:查找到的文件的详细路径信息保存至指定文件中; |
-okCOMMAND {} \:对每个文件执行指定的命令之前需要用户事先确认; |
-execCOMMAND {} \:无需用户确认; |
实例1:查找/var目录属主为root,且属组为mail的所有文件
实例2:查找/usr目录下不属于root、bin或test的所有文件
实例3:查找/etc目录下最近一周内其内容修改过,且属主不为root或hadoop的所有文件
实例4:查找当前系统上没有属主或属组,且最近一周内曾被访问过的所有文件
实例5:查找/etc目录下大于20k且类型为普通文件的所有文件
实例6:查找/etc目录下至少有一类用户没有执行权限的文件
实例7:查找/etc/init.d目录下,所有用户都有执行权限,且其它用户拥有写权限的文件
总结
find命令在Linux日常运维使用中是用到最多命令之一,和locate命令的区别是,find命令是全盘搜索,刚创建的文件也能搜索的到,而locate是模糊搜索,特点就是搜索速度快,但是新创建的文件如果没有收录到文件资料库中,使用locate命令是搜索不到的。
猜你喜欢
- 2025-05-27 linux搜索命令
- 2025-05-27 [Linux Shell]简单的文件查找脚本
- 2025-05-27 Linux查看文件大小:`ls`和`du`为何结果不同?一文讲透原理!
- 2025-05-27 一天一个Linux命令:文件的查看「查」
- 2025-05-27 身边优秀同事都在用的搜索软件,文件再乱秒找到 文档内容也能查
- 2025-05-27 6个使用正则表达式搜索文本中内容的工具
- 2025-05-27 Linux:命令 stat 显示文件的状态信息,命令 find 搜索文件详解
欢迎 你 发表评论:
- 10-23Excel计算工龄和年份之差_excel算工龄的公式year
- 10-23Excel YEARFRAC函数:时间的"年份比例尺"详解
- 10-23最常用的10个Excel函数,中文解读,动图演示,易学易用
- 10-23EXCEL中如何计算截止到今日(两个时间中)的时间
- 10-2390%人不知道的Excel神技:DATEDIF 精准计算年龄,告别手动算错!
- 10-23计算工龄及工龄工资(90%的人搞错了):DATE、DATEDIF组合应用
- 10-23Excel中如何计算工作日天数?用这两个函数轻松计算,附新年日历
- 10-23怎样快速提取单元格中的出生日期?用「Ctrl+E」批量搞定
- 最近发表
-
- Excel计算工龄和年份之差_excel算工龄的公式year
- Excel YEARFRAC函数:时间的"年份比例尺"详解
- 最常用的10个Excel函数,中文解读,动图演示,易学易用
- EXCEL中如何计算截止到今日(两个时间中)的时间
- 90%人不知道的Excel神技:DATEDIF 精准计算年龄,告别手动算错!
- 计算工龄及工龄工资(90%的人搞错了):DATE、DATEDIF组合应用
- Excel中如何计算工作日天数?用这两个函数轻松计算,附新年日历
- 怎样快速提取单元格中的出生日期?用「Ctrl+E」批量搞定
- Excel日期函数之DATEDIF函数_excel函数datedif在哪里
- Excel函数-DATEDIF求司龄_exceldatedif函数计算年龄
- 标签列表
-
- 下划线是什么 (87)
- 精美网站 (58)
- qq登录界面 (90)
- nginx 命令 (82)
- nginx .http (73)
- nginx lua (70)
- nginx 重定向 (68)
- Nginx超时 (65)
- nginx 监控 (57)
- odbc (59)
- rar密码破解工具 (62)
- annotation (71)
- 红黑树 (57)
- 智力题 (62)
- php空间申请 (61)
- 按键精灵 注册码 (69)
- 软件测试报告 (59)
- ntcreatefile (64)
- 闪动文字 (56)
- guid (66)
- abap (63)
- mpeg 2 (65)
- column (63)
- dreamweaver教程 (57)
- excel行列转换 (56)

本文暂时没有评论,来添加一个吧(●'◡'●)