查找
locate
- 依赖文件索引数据库 /var/lib/mlocate/mlocate.db
构建文件索引数据库 updatedb
- locate KEYWORD
options |
comment |
-i |
不区分大小写的搜索 |
-n N |
只列举前N各匹配项 |
-r |
使用基本的正则表达式 |
updatedb
locate conf
locate -r '\.conf$'
find
语法
find [OPTION]...[查找路径] [查找条件] [处理动作]
- 查找路径:指定具体目标路径;默认为当前目录
- 查找条件:指定查找标准,可以文件名、大小、类型、权限等标准进行;
- 处理动作:对符合条件的文件做操作,默认输出至屏幕
查找条件
- 指定搜索层级
option |
comments |
-maxdepth level |
最大搜索目录深度,目录下的文件为第1级 |
-mindepth level |
最小搜索目录深度 |
- 根据文件名查找
option |
comments |
-name "file_name" |
支持使用glob * . [] [^] |
-iname "file_name" |
不区分字母大小写 |
-regex "PATTERN" |
以PATTERN匹配整个文件路径,而非文件名称 |
- 根据属主、属组查找:
option |
comments |
-user USERNAME |
查找属主为指定用户(UID)的文件 |
-group GROUPNAME |
查找属组为指定组(GID)的文件 |
-uid USERID |
查找属主为指定UID号的文件 |
-gid GROUPID |
查找属组为指定GID号的文件 |
-nouser |
查找没有属主的文件 |
-nogroup |
查找没有属组的文件 |
- 根据文件类型查找 -type TYPE
TYPE |
commet |
f |
普通文件 |
d |
目录 |
l |
符号链接 |
s |
套接字文件 |
b |
块设备文件 |
c |
字符设备文件 |
p |
管道文件 |
-empty |
空文件或空目录 |
- 组合条件
find / -user tom -group tom -name *.ba*
find / -user tom -o -user jerry
find / -user tom -not -group tom
1. 找出/tmp目录下,属主不是root,且文件名不以f开头的文件
find /tmp -not -user root -a not -name f*
2. 排除目录
1) 查找/etc/下,除/etc/sane.d目录的其它所有.conf后缀的文件
find /etc/ -path '/etc/sane.d' -a -prune -o -name *.conf
2) 查找/etc/下,除/etc/sane.d和/etc/fonts两个目录的所有.conf后缀的文件
find /etc/ -path "/etc/sane.d" -o -path "/etc/fonts" -a -prune -o -name *.conf
- 根据文件大小查找 -size [+|-] #UNIT
常用单位:k,M,G,c(byte)
mode |
comments |
#UNIT |
(#-1,#],-size 6k: (5k, 6k] - 文件大于5k小于等于6k |
-#UNIT |
[0, #-1], -size -6k: [0,5k] - 文件大于0小于等于5k |
+#UNIT |
(#, unlimit),-size +6k:(6k, ulimit) - 文件大于6k |
- 根据时间查找
format |
comment |
# |
[#, #+1) |
+# |
[#+1, unlimit] |
-# |
[0, #) |
- 根据权限查找 -perm [/|-] MODE
format |
comments |
MODE |
精确匹配,find -perm 755 |
/MODE |
任何一类(u,g,o)对象的权限中只要有一位匹配即可,或的关系;find -perm /222 只要任意人有写权限即匹配 |
-MODE |
每一类对象都必须同时拥有指定权限,与关系;find -perm -222只有每个人都有写权限时才匹配;find -perm -002 只有other有写权限才匹配 |
0 |
表示不关注 |
处理动作
option |
comments |
-print |
默认处理动作,显示至屏幕 |
-ls |
对查找到的文件做‘ls -al’命令 |
-delete |
删除查找到的文件 |
-fls file |
查找到的所有文件的长格式信息保存至指定文件中 |
-ok COMMAND {} ; |
对查找到的每个文件执行COMMAND命令,对于每个命令执行前都会要交用户确认 |
-exec COMMAND {} ; |
对查找到的每个文件执行由COMMAND指定的命令 |
{} |
用于引用查找到的文件名称自身 |
note |
find传递查找到的文件至后面指定的命令时,查找到所有符合条件的文件一次性 传递给后面的命令 |
参数替换xargs
用于产生某个命令的参数,xargs可以读入stdin数据,并且以空格或回车符将stdin数据分割成为参数
ls | xargs rm #删除当前目录下的文件
find /sbin/ -perm /7000 | xargs ls -Sl
find /sbin/ -perm -7000 | xargs ls -Sl
find -type f -name *.txt -print0 | xargs -0 rm
查找示例
# 1. 备份配置文件,添加.orig这个扩展名
find -name "*.conf" -exec cp {} \backup\config\{}.org \;
# 2. 提示删除存在时间超过3天以上的joe的临时文件
find -ctime +3 -user joe -ok rm {} \;
# 3. 在主目录中寻找可被其它用户写入的文件, 并取消写的权限
find ~ -perm 002 -exec chmod o-w {} \;
# 4. 查找/data下的权限为644,后缀为sh的普通文件,增加执行权限
find /data -perm 644 -name ".sh" -type f -exec chmod a+x {} \;
# 5. 查看/home的目录
find /home -type d -ls
# 6. 查找/var目录下属主为root,且属组为mail的所有文件
find /var -user root -group mail
# 7. 查找/var目录下不属于root、lp、gdm的所有文件
find /var -not \( -user root -or -user lp -or -user gdm \)
# 8. 查找/var目录下最近一周内其内容修改过,同时属主不为root,也不是postfix 的文件
find /var -mtime -7 -not \( -user root -or -name "posfix" \)
9. 查找当前系统上没有属主或属组,且最近一个周内曾被访问过的文件
find / -atime -7 -nouser -nogroup
10. 查找/etc目录下大于1M且类型为普通文件的所有文件
find /etc -size +1M -type f
11. 查找/etc目录下所有用户都没有写权限的文件
find /etc -not -perm -222
12. 查找/etc目录下至少有一类用户没有执行权限的文件
find /etc -not -perm /111
13. 查找/etc/init.d目录下,所有用户都有执行权限,且其它用户有写权限的文件
find /etc/init.d/ -perm -111 -perm -002
压缩解压缩
gzip/gunzip
- gzip [option]...file
option |
comment |
-d |
解压缩,== gunzip |
-c |
结果输出到标准输出,保留源文件不变 |
-# |
指定压缩比,#取值为1-9,9最高 |
- zcat file.gz 不显示解压缩的前提下查看文件
bzip2/bunzip2/bzcat
bzip2 [option]...file...
option |
comment |
-k |
保留源文件 |
-d |
解压缩 == bunzip2 file.bz2 |
-# |
设置压缩比 |
xz/unxz/zxcat
xz [option]... FILE...
option |
comment |
-k |
保留原文件 |
-d |
解压缩 == unxz file.xz |
-# |
设置压缩比 |
打包解包
zip/unzip
- 打包压缩
zip -r /backup/sysconfig /etc/sysconfig/
- 解包解压缩
upzip /backup/sysconfig.zip
tar
command |
function |
tar -cpvf /path/file.tar file..... |
创建归档,保留权限 |
tar -r -f /path/file.tar file...... |
追加文件至归档,不支持压缩文件追加 |
tar -t -f /path/file.tar |
查看归档文件中的文件列表 |
tar -x -f /path/file.tar -C /PATH/ |
展开文档,-c指定展开路径,默认当前文档 |
-z:gzip, -j:bzip2, -J:xz |
归档并压缩 |
-exclude |
排除文件tar zcvf /root/a3.tgz --exclude=/app/host1 --exclude=/app/host2 /app |
-T 指定输入文件,-X 排除文件 |
tar zcvf mybackup.tgz -T /root/includefilelist -X /root/excludefilelist |
split |
分割一个文件为多个文件,分割一个 大tar文件为多份小文件: split -b size -d tar-file-name prefix-name |
合并 |
cat mybackup-part* > mybackup.tar.gz |
cpio
复制文件从或到归档
- 格式
- cpio [option] > 文件名或设备名
- cpio [option] < 文件名或设备名
-
示例
command | comments
--|--
find ./etc -print | cpio -ov > back.cpio | 将etc目录备份
find /data | cpio -oA -F bak.cpio
cpio -tv < etc.cpio | 内容预览
cpio -idv < etc.cpio | 解包文件