个人简介:大家好,我是 金鱼哥,CSDN运维领域新星创作者,华为云·云享专家,阿里云社区·专家博主
个人资质:CCNA、HCNP、CSNA(网络分析师),软考初级、中级网络工程师、RHCSA、RHCE、RHCA、RHCI、ITIL
格言:努力不一定成功,但要想成功就必须努力支持我:可点赞、可收藏⭐️、可留言
运维小白暖暖刚在培训机构学习完云计算运维课程后,就想去找一份10K+的工作。谁知道面试的时候,人家面试官注重基础,一上来就一套笔试题仍过去,暖暖一看,oh,my god♀️find是怎么用的啊?等等,scp 又是啥?rsync又是啥解压缩?没用过啊顿时觉得这个世界不眷顾她
这场景,金鱼哥看不过眼了,来,手把手教你玩转他。要收费吗?当然不用,只要认真看这文章就OK
在文件系统上查找符合条件的文件
文件查找:locate, find
locate 查询系统上预建的文件索引数据库 /var/lib/mlocate/mlocate.db
索引的构建是在系统较为空闲时自动进行(周期性任务),执行updatedb可以更新数据库
索引构建过程需要遍历整个根文件系统,很消耗资源
来自于mlocate包
工作特点:
格式:
locate [OPTION]... [PATTERN]...
常用选项
-i 不区分大小写的搜索
-n N 只列举前N个匹配项目
-r 使用基本正则表达式
范例: locatedb创建数据库
[root@servera]# locate conf
locate: can not stat () `/var/lib/mlocate/mlocate.db': No such file or directory
[root@servera]# updatedb
[root@servera]# ll /var/lib/mlocate/mlocate.db
-rw-r-----. 1 root slocate 3090337 Apr 7 16:13 /var/lib/mlocate/mlocate.db
[root@servera]# locate -n 3 conf
/boot/config-4.18.0-193.el8.x86_64
/boot/grub2/i386-pc/configfile.mod
/boot/loader/entries/b6d16ca3e4814c4c92e10837fb500b0a-0-rescue.conf
范例:
#搜索名称或路径中包含“conf”的文件
locate conf
#使用Regex来搜索以“.conf”结尾的文件
locate -r '\.conf$'
find 是实时查找工具,通过遍历指定路径完成文件查找
工作特点:
格式:
find [OPTION]... [查找路径] [查找条件] [处理动作]
查找路径:指定具体目标路径;默认为当前目录
查找条件:指定的查找标准,可以文件名、大小、类型、权限等标准进行;默认为找出指定路径下的所有文件
处理动作:对符合条件的文件做操作,默认输出至屏幕
范例:
[root@servera ~]# find
.
./.bash_logout
./.bash_profile
./.cshrc
./.tcshrc
./anaconda-ks.cfg
./.cache
./.cache/dconf
./.cache/dconf/user
./.cache/libgweather
./.cache/evolution
./.cache/evolution/addressbook
./.cache/evolution/addressbook/trash
./.cache/evolution/calendar
./.cache/evolution/calendar/trash
./.cache/evolution/mail
./.cache/evolution/mail/trash
./.cache/evolution/memos
...
-maxdepth level 最大搜索目录深度,指定目录下的文件为第1级
-mindepth level 最小搜索目录深度
范例:
find /etc -maxdepth 2 -mindepth 2
范例:
[root@servera ~]# mkdir /data/test/test1/test2 -p
[root@servera ~]# touch /data/test/f{1..2}.txt
[root@servera ~]# touch /data/test/test1/test2/f{3..4}.txt
[root@servera data]# tree /data/test/
/data/test/
├── f1.txt
├── f2.txt
└── test1
└── test2
├── f3.txt
└── f4.txt
2 directories, 4 files
[root@servera data]# find /data -maxdepth 2 -mindepth 1
/data/test
/data/test/f1.txt
/data/test/f2.txt
/data/test/test1
-depth / -d
范例:
[root@servera data]# find /data/test
/data/test
/data/test/f1.txt
/data/test/f2.txt
/data/test/test1
/data/test/test1/test2
/data/test/test1/test2/f3.txt
/data/test/test1/test2/f4.txt
[root@servera data]# find /data/test -depth
/data/test/f1.txt
/data/test/f2.txt
/data/test/test1/test2/f3.txt
/data/test/test1/test2/f4.txt
/data/test/test1/test2
/data/test/test1
/data/test
-name "文件名称":支持使用glob,如:*, ?, [], [^],通配符要加双引号引起来
-iname "文件名称":不区分字母大小写
-inum n 按inode号查找
-samefile name 相同inode号的文件
-links n 链接数为n的文件
-regex “PATTERN”:以PATTERN匹配整个文件路径,而非文件名称
范例:
find -name snow.png
find -iname snow.png
find / -name ".txt"
find /var -name "log*"
[root@servera data]# find -regex ".*\.txt$"
./test/f1.txt
./test/f2.txt
./test/test1/test2/f3.txt
./test/test1/test2/f4.txt
-user USERNAME:查找属主为指定用户(UID)的文件
-group GRPNAME: 查找属组为指定组(GID)的文件
-uid UserID:查找属主为指定的UID号的文件
-gid GroupID:查找属组为指定的GID号的文件
-nouser:查找没有属主的文件
-nogroup:查找没有属组的文件
-type TYPE
TYPE可以是以下形式:
f: 普通文件
d: 目录文件
l: 符号链接文件
s:套接字文件
b: 块设备文件
c: 字符设备文件
p: 管道文件
范例:
[root@servera data]# find -type f
./test/f1.txt
./test/f2.txt
./test/test1/test2/f3.txt
./test/test1/test2/f4.txt
./test/f1
[root@servera data]# find -type d
.
./test
./test/test1
./test/test1/test2
[root@servera data]# find -type d -ls
67299970 0 drwxr-xr-x 3 root root 18 Apr 7 16:26 .
101802332 0 drwxr-xrwt 3 root root 57 Apr 7 16:35 ./test
34379336 0 drwxr--r-- 3 root root 19 Apr 7 16:28 ./test/test1
68403853 0 dr-xr--r-- 2 root root 34 Apr 7 16:28 ./test/test1/test2
-empty
范例:
find /data -type f -empty
与:-a ,默认多个条件是与关系
或:-o
非:-not !
范例:
[root@servera data]# find /home -user user1 -a -type d
/home/user1
/home/user1/.mozilla
/home/user1/.mozilla/extensions
/home/user1/.mozilla/plugins
/home/user1/.cache
/home/user1/.ssh
[root@servera data]# find /data/ -type f
/data/test/f1.txt
/data/test/f2.txt
/data/test/test1/test2/f3.txt
/data/test/test1/test2/f4.txt
/data/test/f1
[root@servera data]# find /data/ -type f -o -type d
/data/
/data/test
/data/test/f1.txt
/data/test/f2.txt
/data/test/test1
/data/test/test1/test2
/data/test/test1/test2/f3.txt
/data/test/test1/test2/f4.txt
/data/test/f1
德·摩根定律:
示例:
!A -a !B = !(A -o B)
!A -o !B = !(A -a B)
范例:
[root@servera data]# find ! \( -type f -a -type d \) ----> -type f -o -tpye d
.
./test
./test/f1.txt
./test/f2.txt
./test/test1
./test/test1/test2
./test/test1/test2/f3.txt
./test/test1/test2/f4.txt
./test/f1
[root@servera data]# find -type f -a -type d
[root@servera data]# find /home \( -user student -a -type d \)
/home/student
/home/student/.mozilla
/home/student/.mozilla/extensions
/home/student/.mozilla/plugins
/home/student/.config
/home/student/.config/pulse
/home/student/.cache
/home/student/student
/home/student/test
/home/student/.vim
[root@servera data]# find /home ! \( -user student -a -type d \)
/home
/home/student/.bash_logout
/home/student/.bash_profile
/home/student/.bashrc
/home/student/.config/pulse/b6d16ca3e4814c4c92e10837fb500b0a-device-volumes.tdb
/home/student/.config/pulse/b6d16ca3e4814c4c92e10837fb500b0a-stream-volumes.tdb
范例:
#查找/etc/下,除/etc/sane.d目录的其它所有.conf后缀的文件
find /etc -path '/etc/sane.d' -a -prune -o -name "*.conf"
-size [+|-]#UNIT
常用单位:k, M, G,c(byte),注意大小写敏感
#UNIT: (#-1, #]
如:6k 表示(5k,6k]
-#UNIT:[0,#-1]
如:-6k 表示[0,5k]
+#UNIT:(#,∞)
如:+6k 表示(6k,∞)
范例:
find / -size 10G
find / -size -10G
find / -size +10G
#以“天”为单位
-atime [+|-]#
-mtime
-ctime
#: [#,#+1)
-#: [0,#)
+#: [#+1,∞]
-mtime 10
-mtime -10
-mtime +10
#以“分钟”为单位
-amin
-mmin
-cmin
-perm [/|-]MODE
MODE: 精确权限匹配
/MODE:任何一类(u,g,o)对象的权限中只要能一位匹配即可,或关系,+ 从Rhel 7开始淘汰
-MODE:每一类对象都必须同时拥有指定权限,与关系
0 表示不关注
说明:
find -perm 755 会匹配权限模式恰好是755的文件
只要当任意人有写权限时,find -perm /222就会匹配
只有当每个人都有写权限时,find -perm -222才会匹配
只有当其它人(other)有写权限时,find -perm -002才会匹配
-print:默认的处理动作,显示至屏幕
-ls:类似于对查找到的文件执行"ls -dils"命令格式输出
-fls file:查找到的所有文件的长格式信息保存至指定文件中,相当于 -ls > file
-delete:删除查找到的文件,慎用!
-ok COMMAND {} \; 对查找到的每个文件执行由COMMAND指定的命令,对于每个文件执行命令之前,都会
交互式要求用户确认
-exec COMMAND {} \; 对查找到的每个文件执行由COMMAND指定的命令
{}: 用于引用查找到的文件名称自身
范例:
#备份配置文件,添加.orig这个扩展名
find -name *.conf -exec cp {} {}.orig \;
#提示删除存在时间超过3天以上的joe的临时文件
find /tmp -ctime +3 -user joe -ok rm {} \;
#在主目录中寻找可被其它用户写入的文件
find ~ -perm -002 -exec chmod o-w {} \;
#查找/data下的权限为644,后缀为sh的普通文件,增加执行权限
find /data –type f -perm 644 -name "*.sh" –exec chmod 755 {} \;
压缩比:xz > bzip2 > gz
格式:
gzip [OPTION]... FILE ...
常用选项:
-k keep, 保留原文件,RHEL 8 新特性
-d 解压缩,相当于gunzip
-c 结果输出至标准输出,保留原文件不改变
-# 指定压缩比,#取值为1-9,值越大压缩比越大
范例:
#解压缩
gunzip file.gz
#不显式解压缩的前提下查看文本文件内容
zcat file.gz
范例
gzip -c messages >messages.gz
gzip -c -d messages.gz > messages
zcat messages.gz > messages
cat messages | gzip > m.gz
来自于 bzip2 包
格式:
bzip2 [OPTION]... FILE ...
常用选项
-k keep, 保留原文件
-d 解压缩
-c 结果输出至标准输出,保留原文件不改变
-# 1-9,压缩比,默认为6
范例:
bunzip2 file.bz2 解压缩
bzcat file.bz2 不显式解压缩的前提下查看文本文件内容
来自于 xz 包
格式
xz [OPTION]... FILE ...
常用选项
-k keep, 保留原文件
-d 解压缩
-c 结果输出至标准输出,保留原文件不改变
-# 压缩比,取值1-9,默认为9
范例:
unxz file.xz 解压缩
xzcat file.xz 不显式解压缩的前提下查看文本文件内容
zip 可以实现打包目录和多个文件成一个文件并压缩,但可能会丢失文件属性信息,如:所有者和组信息,一般建议使用 tar 代替
来自于zip 和 unzip 包
范例:
#打包并压缩
zip -r /backup/sysconfig.zip /etc/sysconfig/
#不包括目录本身,只打包目录内的文件和子目录
cd /etc/sysconfig; zip -r /root/sysconfig.zip *
#默认解压缩至当前目录
unzip /backup/sysconfig.zip
#解压缩至指定目录,如果指定目录不存在,会在其父目录(必须事先存在)下自动生成
unzip /backup/sysconfig.zip -d /tmp/config
cat /var/log/messages | zip messages -
#-p 表示管道
unzip -p message.zip > message
范例: 非交互式加密和解密
[root@servera test]#zip -P 123456 test.zip *
adding: ca.crt (deflated 25%)
adding: client.o (deflated 27%)
adding: dh.pem (deflated 19%)
adding: ta.key (deflated 40%)
[root@servera test]#mv test.zip /opt
[root@servera test]#cd /opt
[root@servera opt]#unzip -P 123456 test.zip
Archive: test.zip
[test.zip] ca.crt password:
inflating: ca.crt
inflating: client.o
inflating: dh.pem
inflating: ta.key
tar 即 Tape ARchive 磁带归档,可以对目录和多个文件打包一个文件,并且可以压缩,保留文件属性不
丢失,常用于备份功能,推荐使用
格式
tar [OPTION]...
选项:
-c #创建打包文件
-p #保留权限
-x #解包
-r #追加文件
-t #列表列出
-f #使用文档文件
(1) 创建归档,保留权限
tar -cpvf /PATH/FILE.tar FILE...
(2) 追加文件至归档: 注:不支持对压缩文件追加
tar -rf /PATH/FILE.tar FILE...
(3) 查看归档文件中的文件列表
tar -t -f /PATH/FILE.tar
(4) 展开归档
tar xf /PATH/FILE.tar
tar xf /PATH/FILE.tar -C /PATH/
(5) 结合压缩工具实现:归档并压缩
-z 相当于gzip压缩工具
-j 相当于bzip2压缩工具
-J 相当于xz压缩工具
范例:
[root@servera test]# tar jcvf etc.tar.bz2 /etc/
[root@servera test]# tar Jcvf etc.tar.xz /etc/
[root@servera test]# tar zcvf etc.tar.gz /etc/
[root@servera test]# ll
total 31260
-r--r--r--. 1 root root 5498569 Apr 7 21:15 etc.tar.bz2
-r--r--r--. 1 root root 7150891 Apr 7 21:15 etc.tar.gz
-r--r--r--. 1 root root 4741700 Apr 7 21:16 etc.tar.xz
scp [options] SRC... DEST/
两种方式:
scp [options] [user@]host:/sourcefile /destpath
scp [options] /sourcefile [user@]host:/destpath
常用选项:
-C 压缩数据流
-r 递归复制
-p 保持原文件的属性信息
-q 静默模式
-P PORT 指明remote host的监听的端口
rsync工具可以基于ssh和rsync协议实现高效率的远程系统之间复制文件,使用安全的shell连接做为传
输方式,比scp更快,基于增量数据同步,即只复制两方不同的文件,此工具来自于rsync包
注意:通信两端主机都需要安装 rsync软件
rsync -av /etc server1:/tmp #复制目录和目录下文件
rsync -av /etc/ server1:/tmp #只复制目录下文件
常用选项:
-n 模拟复制过程
-v 显示详细过程
-r 递归复制目录树
-p 保留权限
-t 保留修改时间戳
-g 保留组信息
-o 保留所有者信息
-l 将软链接文件本身进行复制(默认)
-L 将软链接文件指向的文件复制
-u 如果接收者的文件比发送者的文件较新,将忽略同步
-z 压缩,节约网络带宽
-a 存档,相当于-rlptgoD,但不保留ACL(-A)和SELinux属性(-X)
--delete 源数据删除,目标数据也自动同步删除
范例:
[root@servera ~]#rsync -auv --delete /data/test 10.0.0.7:/data
交互式文件传输工具,用法和传统的ftp工具相似,利用ssh服务实现安全的文件上传和下载
使用ls cd mkdir rmdir pwd get put等指令,可用?或help获取帮助信息
sftp [user@]host
sftp> help
玩到最后了,心足了吧。好好学,好好找工作,10K+只是起步,找不到10K+都别说是金鱼哥带出来的学生。
RHCSA认证作为基础认证,涉及的基础内容需要大家好好进行学习并巩固。有良好的基础才能更上一层楼。
好好加油,可以噶。
以上就是【金鱼哥】对 第十六章 文件查找、传输和打包压缩 的简述和讲解。希望能对看到此文章的小伙伴有所帮助。
红帽认证专栏系列:
RHCSA专栏:戏说 RHCSA 认证
RHCE专栏:戏说 RHCE 认证
此文章收录在RHCA专栏:RHCA 回忆录
如果这篇【文章】有帮助到你,希望可以给【金鱼哥】点个赞,创作不易,相比官方的陈述,我更喜欢用【通俗易懂】的文笔去讲解每一个知识点。
如果有对【运维技术】感兴趣,也欢迎关注❤️❤️❤️ 【金鱼哥】❤️❤️❤️,我将会给你带来巨大的【收获与惊喜】!