1.find指令
Linux下find命令在目录结构中搜索文件,并执行指定的操作。
1)命令格式:find pathname -options [-print -exec -ok ...] 即 find 查找目录
[查找规则]
2)命令功能:用于在文件树中查找文件,并作出相应的处理(可能访问磁盘)。
3)命令参数:-pathname: find命令所查找的目录路径。例如用 . 来表示当前目录,用 / 来表示系统根目录。
-print: find命令将匹配的文件输出到标准输出。
-exec: find命令对匹配的文件执行该参数所给出的shell命令。相应命令的形式为'command' { } \;,注意 { } 和 \ 之间的空格。
-ok: 和-exec的作用相同,只不过以一种更为安全的模式来执行该参数所给出的shell命令,在执行每一个命令之前,都会给出提示,让用户来确定是否执行。
以上就是关于 -exec 和 -ok 的验证,可以发现二者形式相同,作用相同,只是 -ok 会给出提示让用户确定是否执行此操作,相对而言更加安全。
4)命令选项:-name 按照文件名查找文件。
-perm 按照文件权限来查找文件。
-prune 使用这一选项可以使find命令不在当前指定的目录中查找。
-user 按照文件属主来查找文件。
-group 按照文件所属的组来查找文件。
-nogroup 查找无有效所属组的文件,即该文件所属的组在/etc/groups中不存在。
-nouser 查找无有效属主的文件,即该文件的属主在/etc/passwd中不存在。
-mtime -n +n 按照文件的更改时间来查找文件, - n表示文件更改时间距现在n天以内,+ n表示文件更改时间距现在n天以前。
find命令还有-atime和-ctime 选项,但它们都和-m time选项相同。
-newer file1 ! file2 查找更改时间比文件file1新但比文件file2旧的文件。
-type 查找某一类型的文件,诸如: b -块设备文件。
d - 目录。
c - 字符设备文件。
p - 管道文件。
l - 符号链接文件。
f - 普通文件。
-size n[c] :查找文件长度为n块的文件,带有c 时表示文件长度以字节计。
-depth:在查找文件时,首先查找当前目录中的文件,然后再在其子目录中查找。
-fstype:查找位于某一类型文件系统中的文件,这些文件系统类型通常可以在配置文件/etc/fstab中找到,该配置文件中包含了本系统中有关文件系统的信息。
-mount:在查找文件时不跨越文件系统mount点。
-follow:如果find命令遇到符号链接文件,就跟踪至链接所指向的文件。
-cpio:对匹配的文件使用cpio命令,将这些文件备份到磁带设备中。
以上有些操作并没有达到预期的效果,是因为我并没有创建与之相应的文件,因此查找不到信息。
2.粘滞位
权限粘滞位
通常情况下用户只要对某个目录具备 w 写入权限,便可以删除该目录中的任何文件,而不论这个文件的权限是什么。而当目录被设置了粘滞位权限以后,即便用户对该目
录有写入 w 权限,也不能删除该目录中其他用户的文件数据,而是只有该文件的所有者root用户才有权将其删除。
可以看出虽然普通用户 admin 对文件 /test/file1 只具备 r-- 权限,但因为从 /test 目录获得了 rwx 权限,仍然可以将 /test/file1 删除。
粘滞位权限都是针对其他用户(other)设置,使用chmod命令设置目录权限时,o+t、o-t 权限模式可分别用于添加、移除粘滞位权限。
当我们添加了权限后, x 变为了 t ,说明此时我们已经对目录设置了粘滞位权限。
当我们移除了权限后, t 变为了 x,说明此时我们已经对取消了设置。
设置了粘滞位之后,可以保持一种动态的平衡:允许各用户在目录中任意写入、删除数据,但是禁止随意删除其他用户的数据。
注:粘滞位权限只能针对目录设置,对于文件无效。设置了粘滞位权限的目录,使用 ls 命令查看其属性时,其他用户权限处的 x 将变为 t 。