Linux中有很多查找命令,今天主要讲解locate,find两个命令。
1.locate(1)查询系统上预建的文件索引数据库
/var/lib/mlocate/mlocate.db
注意:如果这个文件删除了,locate就无法使用了。需手动手动更新数据库(updatedb),或重启系统,locate才能恢复作用
依赖于事先构建的索引:
索引的构建是在系统较为空闲时自动进行( 周期性任务 /etc/cron.daily), 管理员手动更新数据库(updatedb)
索引构建过程需要遍历整个根文件系统,极消耗资源
(2)工作特点:
• 查找速度快
• 模糊查找
• 非实时查找
• 搜索的是文件的全路径,不仅仅是文件名
• 只搜索用户具备读取和执行权限的目录,没有权限,即使数据库有内容,也不显示,为了安全
(3)locate 用法
-i 不区分大小写的搜索
-n # 只列举前#个匹配项目
-r 支持正则
实时查找工具,通过遍历指定路径完成文件查找(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同标准的正则