Linux基础知识——文件查找

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

(0)
396064847396064847
上一篇 2016-10-11
下一篇 2016-10-12

相关推荐

  • linux用户,组及权限管理

      写在前面: 本博客详解命令如下: useradd, userdel,usermod, passwd,  chage, groupadd,  groupdel, groupmod, gpasswd ,newgrp, chsh, id, su,  chmod,  chowm,  chgrp, &nb…

    Linux干货 2015-12-19
  • shell编程、yum的使用

    shell编程、yum的使用 一、shell编程 1、while的特殊使用 while 循环的特殊用法(遍历文件的每一行): while read line; do      循环体 done < /PATH/FROM/SOMEFILE   依次读取/PATH/FROM/SOMEFILE 文件…

    Linux干货 2016-08-21
  • 22期第九周课堂作业

    1、写一个脚本,判断当前系统上所有用户的shell是否为可登录shell(即用户的shell不是/sbin/nologin);分别这两类用户的个数;通过字符串比较来实现; #!/bin/bash declare -i a=0 declare -i b=0 n=`cat /etc/passwd |cu…

    Linux干货 2016-10-17
  • 第一周

       注意:请同学们不要参考我这个,怕误导,谢谢 A.计算机组成及其功能     1.计算机的组成分:硬件和软件         硬件:CPU,存储设备(内存,硬盘),输入输出设备(键盘,显示器,鼠标)  &n…

    Linux干货 2016-12-31
  • linux文本处理三剑客-sed

    sed 是什么? sed是一种流编辑器,它是文本处理中非常中的工具,在linux中被称为linux文本处理三剑客之一,能够完美的配合正则表达式使用,功能不同凡响。处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”(pattern space),接着用sed命令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕。接着处理下一行,这样不断重复,直到文…

    Linux干货 2017-03-15
  • 一起学DNS系列(十四)DNS查询工具之DIG的使用(2)

    原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。http://jeffyyko.blog.51cto.com/28563/240243    上节谈到了利用DIG的+trace参数追踪域名解析的过程,其实除此之外,DIG还有一些其他的参数,这节会涉及到这…

    2015-03-17

评论列表(1条)

  • 马哥教育
    马哥教育 2016-10-20 19:30

    这几个工具用好了,可以大幅提高文件查找效率,这篇文章整理的非常不错。