linux find使用教程

find基础知识


文件查找:在文件系统上查找符合条件的文件的过程;

文件查找命令:locate, find

locate: 非实时查找工具;依赖于事先构建的索引;索引的构建是在系统较为空闲时自动进行(周期性任务);手动更新此数据库(updatedb);查找速度快;模糊查找;

find:实时查找;查找速度略慢;精确查找;

find命令:

find [OPTION]... [查找路径] [查找条件] [处理动作]

查找路径:默认为当前路径;

查找条件:指定的查找标准,可以根据文件名、大小、属主属组、类型等进行;默认为找出指定路径下的所有文件;

处理动作:对符合条件的文件做什么操作;默认为输出至屏幕;

查找条件:

根据文件名进行查找:

-name "文件名称": 支持使用glob(*, ?, []);

-iname "文件名称":不区分字符大小写,支持使用glob

-regex "PATTERN":以PATTERN匹配整个文件路径字符串,而不仅仅是文件名称

根据属主、属组查找:

-user USERNAME: 查找属主为指定用户的文件

-group GROUPNAME:

-uid UserID: 查找文件的属主指定uid的文件;

-gid GroupID:

-nouser: 查找没有属主的文件;

-nogroup:查找没有属组的文件;

根据文件类型进行查找:

-type TYPE

type类型有:

f: 普通文件

d: 目录

l: 符号链接

b: 块设备

c: 字符设备

p: 命名管道

s: 套接字

组合查找条件:

与条件:-a

或条件:-o

非条件:-not, !

根据文件大小来查找:

-size [+|-]NUM

单位:k, M, G

+NUM:(NUM,+oo] 查找的值如果设为x(下同), 范围为:x>=NUM

NUM:(NUM-1, NUM] 范围为:NUM-1<=x<NUM

-NUM:[0,NUM-1] 范围为:0<x<NUM-1

根据时间戳:

以“天”为单位

-atime(最近访问时间)

+NUM:[NUM+1, +00] 范围为:x>NUM+1

NUM:[NUM,NUM+1) 范围为NUM<x<=NUM+1

-NUM:[0,NUM) 范围为0<x<=NUM

注意:这项要和-size取值范围一定要区别开来,很容易混淆.

-mtime(最近文件修改时间)

-ctime(最近文件属性修改时间)

根据权限:

-perm [/|-]MODE

MODE: 精确权限匹配

/MODE:任何一类对象(u,g,o)的任何一位权限符合条件即可;隐含或条件;

-MODE:为每一类对象指定的每一位权限都必须同时存在方为符合条件;隐含与条件;

处理动作:

-print: 默认处理动作

-ls:类似于对查找到的每个文件做"ls -l"的操作;

-delete: 删除查找到的文件;

-fls /path/to/somefile:查找到的文件的详细路径信息保存至指定文件中;

-ok COMMAND {} \;

对每个文件执行指定的命令之前需要用户事先确认;

-exec COMMAND {} \;

无需用户确认;

实战

1、查找/var目录属主为root,且属组为mail的所有文件;

解答: find /var -user root -a -group mail

2、查找/usr目录下不属于root、bin或hadoop的所有文件;

解答: find /usr -not \( -user root -o -user bin -o -user hadoop \)

3、查找/etc目录下最近一周内其内容修改过,且属主不为root或hadoop的所有文件;

解答: find /etc -mtime -7 -a -not \( -user root -o -user hadoop \)

4、查找当前系统上没有属主或属组,且最近一周内曾被访问过的所有文件;

解答: find / \( -nouser -o -nogroup \) -a -atime -7

5、查找/etc目录下大于20k且类型为普通文件的的所有文件;

解答: find /etc -size +20k -a -type f

6、查找/etc目录下所有用户都没有写权限的文件;

解答: find /etc -not -perm /222

7、查找/etc目录下至少有一类用户没有执行权限的文件;

解答: find /etc -not -perm -111

8、查找/etc/init.d目录下,所有用户都有执行权限,且其它用户拥有写权限的文件;

解答:find /etc/init.d -perm -111 -a -perm -002


时间: 2024-07-31 14:33:48

linux find使用教程的相关文章

Linux培训基础教程

linux下查询history操作时间的方法 要在linux操作系统中查看history记录的操作时间,可以按如下步骤实现: 兄弟连Linux培训基础教程 1,修改/etc/profile文件,在末尾添加:exporthisttimeformat="%f %t `whoami` " 2,或在用户目录下,修改文件 .bash_profile,添加export histtimeformat="%f%t `whoami` " 退出终端,重新登录. 例,查看history操

Kali Linux 安全渗透教程&lt;第三更&gt;1.2 安全渗透所需工具

了解了渗透测试的概念后,接下来就要学习进行渗透测试所使用的各种工具.在做渗透测试之前,需要先了解渗透所需的工具.渗透测试所需的工具如表1-1所示: 表1-1  渗透所需工具 splint unhide scrub pscan examiner ht flawfinder srm driftnet rats nwipe binwalk ddrescue firstaidkit-gui scalpel gparted xmount pdfcrack testdisk dc3dd wipe forem

进程和程序:编写shell——《Unix/Linux编程实践教程》读书笔记(第8章)

1.Unix shell的功能 shell是一个管理进程和运行程序的程序.所有常用的shell都有3个主要功能: (1)运行程序: (2)管理输入和输出 (3)可编程 shell同时也是带有变量和流程控制的编程语言. 2.Unix的进程模型 一个程序是存储在文件中的机器指令序列,一般它是由编译器将源代码编译成二进制格式的代码.运行一个程序意味着将这些机器指令序列载入内存然后让处理器(CPU)逐条执行.在Unix术语中,一个可执行程序是一些机器指令机器数据的序列.一个进程是程序运行时的内存空间和设

系统调用操作文件——《Unix/Linux编程实践教程》读书笔记

1.who命令通过读系统日志的内容显示当前已经登录的用户. 2.Unix系统把数据存放在文件中,可以通过以下系统调用操作文件: open(filename, how) creat(filename, mode) read(fd, buffer, amt) write(fd, buffer, amt) lseek(fd, distance, base) close(fd) 3.进程对文件的读/写都要通过文件描述符,文件描述符表示文件和进程之间的连接. 4.每次系统调用都会导致用户模式和内核模式的切

Linux Shell系列教程之(七)Shell输出

本文是Linux Shell系列教程的第(七)篇,更多shell教程请看:Linux Shell系列教程 与其他语言一样,Shell中也有输出操作,而且在实际应用中也是非常重要的,今天就为大家介绍下Shell输出操作. Shell echo命令 echo命令是Shell的一个内部指令,用于在屏幕上打印出指定的字符串. 命令格式: echo arg 转义字符 像其他高级语言一样,Shell也使用反斜杠“\”作为转义字符. 例子: echo "\"It is a test\"&q

终端控制和和信号——《Unix/Linux编程实践教程》读书笔记(第6章)

1.有些程序处理从特定设备来的数据.这些与特定设备相关的程序必须控制与设备的连接.Unix系统中最常见的设备是终端. 2.终端驱动程序有很多设置.各个设置的特定值决定了终端驱动程序的模式.为用户编写的程序通常需要设置终端驱动程序为特定的模式. 3.键盘输入分为3类,终端驱动程序对这些输入做不同的处理.大多数建代表常规数据,它们从驱动程序传输到程序.有些键调用驱动程序中的编辑函数.如果按下删除键,驱动程序将前一个字符从它的行缓冲中删除,并将命令发送到终端屏幕,使之从显示器中删除字符.最后,有些键调

Linux Shell系列教程之(六)Shell数组

本文是Linux Shell系列教程的第(六)篇,更多shell教程请看:Linux Shell系列教程 Shell在编程方面非常强大,其数组功能也非常的完善,今天就为大家介绍下Shell数组的用法. Shell支持一维数组(不支持多维数组),并且没有限定数组的大小. 类似与C语言,数组元素的下标由0开始编号.获取数组中的元素要利用下标,下标可以是整数或算术表达式,其值应大于或等于0. 一.Shell数组的定义 在Shell中,用括号来表示数组,数组元素之间用“空格”分割开. 定义数组的一般形式

Kali Linux 安全渗透教程&lt;第七更&gt; 大学霸1.4.3安装至VMware Workstation

Kali Linux 安全渗透教程<第七更>大学霸 1.4.3安装至VMware Workstation VMware Workstation是一款功能强大的桌面虚拟计算机软件.它允许用户在单一的桌面上同时运行不同的操作系统.用户在其中可以进行开发.测试和部署新的应用程序.目前最新版本是10.0.1,官方下载地址https://my.vmware.com/cn/web/vmware/downloads.本节将介绍在VMware Workstation上安装Kali Linux操作系统.Kali

LINUX 安装PHP7教程

linux 安装php7教程 1.首先下载php7对应版本,解压到指定目录 2.安装gcc yum install gcc 3.安装libxml2 yum install -y libxml2-devel 4.执行./configure   (也可以用–prefix=/usr/local/php) 指定安装目录! 5.然后执行 make 6.make install 7.安装完成之后,你可以执行./configure –enable-fpm  –with-curl  - 加载更多的扩展模块!

Linux Shell系列教程之(四)Shell注释

本文是Linux Shell系列教程的第(四)篇,更多shell教程请看:Linux Shell系列教程 与许多的编程语言一样,Shell中也有注释符号,今天就为大家来介绍下Shell中的注释的语法及用法. Shell中的注释以“#”号开头,所有以“#”号开头的代码都会被解释器所忽略. 比如下面的代码: #!/bin/bash # Author : linuxdaxue.com # Date : 2016-05-15 echo "What is your name?" read PER