Linux系统的核心思想之一就是一切皆文件,可想而知你要靠记忆去查找一个文件该是多么费劲;今天我们介绍几个文件查找命令:whereis,locate,find
whereis
locate the binary, source, and manual page files for a command 【SYNOPSIS】 whereis [-bmsu] [-BMS directory... -f] filename... 【OPTIONS】 -b 仅查找二进制文件 -m 仅查找man章节 -s 仅查找源文件
locate
find file by name locate命令与其他查找命令不同在于,它是靠查询一张数据表的内容来查找文件位置:/var/lib/mlocate/mlocate.db而这张表是定时自动更新其内容的,新加的文件或者目录是无法立即查询得到的,通过命令【updatedb】命令来即时更新其数据表来获取最新的文件保存信息 【SYNOPSIS】 locate [OPTION]... PATTERN... 【OPTION】 -b, --basename 仅查找基名的路径 -c,--count 仅显示查找到的数量 -d,--database DBPATH 更改mlocate.db保存路径 -i,--ignore 忽略大小写 -r,--regexp 支持基本正则表达式 --regex 支持扩展正则表达式 -l,--limit -n LIMIT 指定显示数量 -P,--nofollow 不显示链接指向符号检测文件是否存在 -L,--follow 与-P相反
find
search for files in a directory hierarchy 【SYNOPSIS】 find [-H] [-L] [-P] [-D debugopts] [-Olevel] [path...] [expression] 【OPTIONS】 -P Never follow symbolic links(defualt) -L Follow symbolic links -H Do not follow symbolic links, except while processing the command line arguments. -nouser 无属主 -nogroup 无属组 -atime 访问时间查找(天数) +n n时间之前的文件 n n时间24小时之内访问的时间(闭合区间) -n n时间到现在的时间 -mtime 修改时间查找(天数) -ctime 改变时间查找(天数) -amin (分钟) -mmin (分钟) -cmin (分钟) -user 按属主查找 -group 按属主查找 -perm 按权限查找 mode 权限精确查找 -mode 每一类用户权限中的每一位权限符合条件即可 /mode 任意一类用户权限中的任意一位权限条件满足即可 -size 按照文件大小查找 +n 大于n的 n 大于等于n,小于n+1 -n 小于n 【EXPRESSION】 -print 标准输出,默认 -ls 将查找到的文件“ls -l”,不支持alias别名命令 -delete 将查找到的文件删除 -fls /PATH/TO/SOMEFILE 将查找到的文件的长格式保存至路径 -ok COMMAND {} \; 对查找到的内容执行COMMAND,并交互确认 -exec COMMAND {} \; 对查找到的内容进行COMMAND find | xargs find文件后执行COMMAND时,不支持长格式参数,如果参数过长会出错,无法执行,则使用此管道命令执行
1、显示当前系统上root、fedora、user1用户的默认shell
grep -E "^(root|fedora|user1)" /etc/passwd |cut -d: -f1,7
2、找出/etc/rc.d/init.d/functions文件中某单词后面跟一个小括号的行
grep "\<[[:alnum:]]*\>[(][)]" /etc/rc.d/init.d/functions
3、使用echo命令输出一个绝对路径,使用grep取出其基名/取出其路径名 echo PATH |grep -o "[^/]+[[:alnum:]][[:punct:]]$" echo /var/spool/mail/root|grep -o "(/).*\1" 4、找出ifconfig命令结果中的1-255之间的数字
ifconfig |grep -E "\<([1-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\>"
5、写一个模式,能匹配合理的IP地址
ifconfig |grep -E "[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}"
6、写一个模式,能匹配出所有的邮件地址
grep -o "[[:alnum:]]\+[[:punct:]]*[[:alnum:]]\+\>@[^[:space:]]\+[[:alnum:]]*\>" /var/spool/mail/root
7、查找/var目录下属主为root,且属组为mail的所有文件或者目录
find /var/ -user root -a -group mail -ls
8、查找当前系统上没有属主或者属组的文件/查找当前系统上没有属主或者属组,且最近三天内曾被访问过的文件或者目录
find / -nouser -o -nogroup -a -atime -3
9、查找/etc/目录下所有用户都有写权限的文件
find /etc/ -perm -222 -exec ls -dl {} \;
10、查找/etc目录下大于1M,且类型为普通文件的所有文件
find /etc -type f -a -size +1M -exec ls -dl {} \;
11、查找/etc/init.d/目录下,所有用户都有执行权限,且其他用户有写权限的文件
find /etc/init.d/ -perm -111 -a -perm -002 -exec ls -l {} \;
12、查找/usr目录下不属于root、bin或者hadoop的文件
find /tmp/ ! -user root -a ! -user bin -a ! -user hadoop -exec ls -l {} \;
13、查找/etc目录下至少有一类用户没有写权限的文件
find /etc/ ! -perm -222 -exec ls -l {} \;
14、查找/etc目录下最近一周内其内容被修改过,且不属于root或者hadoop的文件
find /etc/ -mtime -7 -a ! -user root -a ! -user hadoop -exec ls -l {} \;
原创文章,作者:396064847,如若转载,请注明出处:http://www.178linux.com/50652
评论列表(1条)
这几个工具用好了,可以大幅提高文件查找效率,这篇文章整理的非常不错。