8月12号,主要内容为如下:
一、使用locate命令
二、使用find命令
三、压缩和解压缩工具
文件查找:在文件系统上查找符合条件的文件;
非实时查找(数据库查找):locate
实时查找:find
一、locate
查询系统上预建的文件索引数据库 /var/lib/mlocate/mlocate.db
依赖于事先构建的索引; 索引的构建是在系统较为空闲时自动进行(周期性任务);
管理员手动更新数据库(updatedb);
1)工作特点:
查找速度快;
模糊查找;
非实时查找搜索的是文件的全路径,不仅仅是文件名
可能只搜索用户具备读取和执行权限的目录
2)用法:
locate KEYWORD
有用的选项:
-i 执行区分大小写的搜索
-n X 只列举前X个匹配项目
locate foo
搜索名称或路径中带有“foo”的文件
locate -r ‘\.foo$’
使用Regex来搜索以“.foo”结尾的文件
二、find
实时查找工具,通过遍历指定路径完成文件查找;
1)工作特点:
查找速度略慢
精确查找
实时查找 可能只搜索用户具备读取和执行权限的目录
2)用法:
find [OPTION]... [查找路径] [查找条件] [处理动作]
查找路径:指定具体目标路径;默认为当前目录
查找条件:指定的查找标准,可以文件名、大小、类型、 权限等标准进行;默认为找出指定路径下的所有文件
处理动作:对符合条件的文件做操作,默认输出至屏幕
3)查找条件
根据文件名和inode查找
-name "文件名称"(双引号不能少):支持使用glob通配符 *, ?, [], [^]
-iname "文件名称":不区分字母大小写
-inum n 按inode号查找
-samefile name 相同inode号的文件
-links n 链接数为n的文件
-regex "PATTERN":以PATTERN匹配整个文件路径字符串,而不仅仅是文件名称
根据属主、属组查找:
-user USERNAME:查找属主为指定用户(UID)的文件
-group GRPNAME: 查找属组为指定组(GID)的文件
-uid UserID:查找属主为指定的UID号的文件
-gid GroupID:查找属组为指定的GID号的文件
-nouser:查找没有属主的文件
-nogroup:查找没有属组的文件
根据文件类型查找:
-type TYPE:
f: 普通文件
d: 目录文件
l: 符号链接文件
s:套接字文件
b: 块设备文件
c: 字符设备文件
p: 管道文件
根据文件大小来查找:
-size [+|-]#UNIT
常用单位:k, M, G
#UNIT: (#-1, #],如:6k
-#UNIT:[0,#-1], 如:-6k
+#UNIT:(#,∞), 如:+6k
根据时间戳查找:
以“天”为单位:(#代表区间不同于按大小查找时)
-atime [+|-]#,
#: [#,#+1)
+#: [#+1,∞]
-#: [0,#)
-mtime
-ctime
以“分钟”为单位:
-amin -mmin -cmin
注意:-mmin-1 能匹配到一分钟内创建的文件,而-mmin 1实际上也能找到一分钟内创建的文件,笔者猜想可能和分钟数变化的刻度有关,未满一分钟的即认定为1分钟,满一分未满两分的算两分,但这不能说明为什么-mmin-1 能匹配到一分钟内创建的文件)
根据权限查找:
用法:-perm [/|-]MODE
MODE: 精确权限匹配
/MODE(原+MODE):任何一类(u,g,o)对象的权限中只要能一位匹配 即可,或关系,原来的+ 从centos7开始淘汰
-MODE:每一类对象都必须同时拥有指定权限,与关系
0 表示不关注
find -perm 755 会匹配权限模式恰好是755的文件
只要当任意人有写权限时,find -perm +222就会匹配
只有当每个人都有写权限时,find -perm -222才会匹配
只有当其它人(other)有写权限时,find -perm -002才 会匹配
组合条件
组合条件: 与-a 或-o 非-not, !
德·摩根定律:
非(P 且 Q) = (非 P) 或 (非 Q)
非(P 或 Q) = (非 P) 且 (非 Q)
实例:
找出/tmp目录下,属主不是root,且文件名不是fstab的文件
find /tmp \( -not -user root -a -not -name ‘fstab‘ \) ls
find /tmp -not \( -user root -o -name ‘fstab‘ \) –ls
排除目录 find /etc -path ‘/etc/sane.d’ -a -prune -o -name *.conf -print
4)处理动作
-print:默认的处理动作,显示至屏幕;
-ls:类似于对查找到的文件执行“ls -l”命令
-delete:删除查找到的文件;
-fls file:查找到的所有文件的长格式信息保存至指定文件中
-ok COMMAND {} \; 对查找到的每个文件执行由 COMMAND指定的命令; 对于每个文件执行命令之前,都会交互式要求用户确认
-exec COMMAND {} \; 对查找到的每个文件执行由 COMMAND指定的命令
{}: 用于引用查找到的文件名称自身
find传递查找到的文件至后面指定的命令时,查找到所有符合条件的文件一次性传递给后面的命令
若找到的结果数量过多,超过命令能处理的最多参数量,会造成命令无法执行,此时可用
-exec | xargs COMMAND {} \
实例:
find -name “*.conf” -exec cp {} {}.org \;
备份配置文件,添加.orig这个扩展名
find /tmp -ctime +3 -user joe -ok rm {} \;
提示删除存在时间超过3天以上的joe的临时文件
find ~ -perm -002 -exec chmod o-w {} \;
在你的主目录中寻找可被其它用户写入的文件
find /data –type f -perm 644 -name *.sh – exec chmod 755 {} \;
find /home –type d -ls 显示家目录下的子目录
四、压缩、解压缩及归档工具
1)file-roller图形界面压缩
2)compress/uncompress: .Z(默认删掉原文件)
compress [-dfvcVr] [-b maxbits] [file ...]
-d: 解压缩,相当于 uncompress
-c: 结果输出至标准输出,不删除原文件
-v: 显示详情,过程
uncompress 解压缩
zcat file.Z >file 解压缩至标准输出,再重定向
3)gzip/gunzip: .gz
gzip [OPTION]... FILE ...
-d: 解压缩,相当于gunzip
-c: 将压缩或解压缩的结果输出至标准输出
-#:1-9,指定压缩比,值越大压缩比越大
zcat:不显式解压缩的前提下查看文本文件内容
实例:
gzip -c messages >messages.gz
gzip -c -d messages.gz > messages
zcat messages.gz > messages
4)bzip2/bunzip2: .bz2
bzip2 [OPTION]... FILE ...
-k: keep, 保留原文件
-d:解压缩
-#:1-9,压缩比,默认为6
bzcat:不显式解压缩的前提下查看文本文件内容;
5)xz/unxz: .xz
xz2 [OPTION]... FILE ...
-k: keep, 保留原文件
-d:解压缩
-#:1-9,压缩比,默认为6
xzcat:不显式解压缩的前提下查看文本文件内容;
6)zip/unzip
打包压缩 zip –r sysconfig sysconfig/
解包解压缩
unzip sysconfig.zip
cat /var/log/messages | zip message
unzip -p message > message
本文出自 “笑猴子” 博客,请务必保留此出处http://xiaomonkey.blog.51cto.com/11869371/1837864
原文地址:http://xiaomonkey.blog.51cto.com/11869371/1837864