运维初哥不要紧,手把手教你运用文件查找、打包和传输文件

个人简介:大家好,我是 金鱼哥,CSDN运维领域新星创作者,华为云·云享专家,阿里云社区·专家博主
个人资质:CCNA、HCNP、CSNA(网络分析师),软考初级、中级网络工程师、RHCSA、RHCE、RHCA、RHCI、ITIL
格言:努力不一定成功,但要想成功就必须努力

支持我:可点赞、可收藏⭐️、可留言


运维小白暖暖刚在培训机构学习完云计算运维课程后,就想去找一份10K+的工作。谁知道面试的时候,人家面试官注重基础,一上来就一套笔试题仍过去,暖暖一看,oh,my god‍♀️find是怎么用的啊?等等,scp 又是啥?rsync又是啥解压缩?没用过啊顿时觉得这个世界不眷顾她

这场景,金鱼哥看不过眼了,来,手把手教你玩转他。要收费吗?当然不用,只要认真看这文章就OK


文章目录

      • 16.1 文件查找
        • 16.1.1 locate
        • 16.1.2 find
          • 16.1.2.1 指定搜索目录层级
          • 16.1.2.2 对每个目录先处理目录内的文件,再处理目录本身
          • 16.1.2.3 根据文件名和inode查找
          • 16.1.2.4 根据属主、属组查找
          • 16.1.2.5 根据文件类型查找
          • 16.1.2.6 空文件或目录
          • 16.1.2.7 组合条件
          • 16.1.2.8 排除目录
          • 16.1.2.9 根据文件大小来查找
          • 16.1.2.10 根据时间戳
          • 16.1.2.11 根据权限查找
          • 16.1.2.12 处理动作
      • 16.2 压缩和解压缩
        • 16.2.1 gzip和gunzip
        • 16.2.2 bzip2和bunzip2
        • 16.2.3 xz和unxz
        • 16.2.4 zip和unzip
      • 16.3 打包和解包tar
      • 16.4 文件传输
        • 16.4.1 scp命令
        • 16.4.2 rsync 命令
        • 16.4.3 sftp
    • 总结

16.1 文件查找

在文件系统上查找符合条件的文件
文件查找:locate, find

  • 非实时查找(数据库查找):locate
  • 实时查找:find

16.1.1 locate

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$'

16.1.2 find

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
...

16.1.2.1 指定搜索目录层级
-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

16.1.2.2 对每个目录先处理目录内的文件,再处理目录本身
-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

16.1.2.3 根据文件名和inode查找
-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

16.1.2.4 根据属主、属组查找
-user USERNAME:查找属主为指定用户(UID)的文件
-group GRPNAME: 查找属组为指定组(GID)的文件
-uid UserID:查找属主为指定的UID号的文件
-gid GroupID:查找属组为指定的GID号的文件
-nouser:查找没有属主的文件
-nogroup:查找没有属组的文件

16.1.2.5 根据文件类型查找
-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

16.1.2.6 空文件或目录

-empty

范例:

find /data -type f -empty

16.1.2.7 组合条件
与:-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) 或 (非 B) = 非(A 且 B)
  • (非 A) 且 (非 B) = 非(A 或 B)

示例:

!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


16.1.2.8 排除目录

范例:

#查找/etc/下,除/etc/sane.d目录的其它所有.conf后缀的文件
find /etc -path '/etc/sane.d' -a -prune -o -name "*.conf"

16.1.2.9 根据文件大小来查找
-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

16.1.2.10 根据时间戳
#以“天”为单位
-atime [+|-]#
-mtime
-ctime

#: [#,#+1)
-#: [0,#)
+#: [#+1,∞]
-mtime 10
-mtime -10
-mtime +10

#以“分钟”为单位
-amin
-mmin
-cmin

16.1.2.11 根据权限查找
-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才会匹配


16.1.2.12 处理动作
-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 {} \;

16.2 压缩和解压缩

  • gzip gunzip
  • bzip2 bunzip2
  • xz unxz
  • zip unzip

压缩比:xz > bzip2 > gz

16.2.1 gzip和gunzip

格式:

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

16.2.2 bzip2和bunzip2

来自于 bzip2 包

格式:

bzip2 [OPTION]... FILE ...

常用选项

-k keep, 保留原文件
-d 解压缩
-c 结果输出至标准输出,保留原文件不改变
-# 1-9,压缩比,默认为6

范例:

bunzip2 file.bz2 	解压缩
bzcat file.bz2 		不显式解压缩的前提下查看文本文件内容

16.2.3 xz和unxz

来自于 xz 包

格式

xz [OPTION]... FILE ...

常用选项

-k keep, 保留原文件
-d 解压缩
-c 结果输出至标准输出,保留原文件不改变
-# 压缩比,取值1-9,默认为9

范例:

unxz file.xz 解压缩
xzcat file.xz 不显式解压缩的前提下查看文本文件内容

16.2.4 zip和unzip

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

16.3 打包和解包tar

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

16.4 文件传输

16.4.1 scp命令
scp [options] SRC... DEST/

两种方式:

scp [options] [user@]host:/sourcefile /destpath
scp [options] /sourcefile [user@]host:/destpath

常用选项:

-C 压缩数据流
-r 递归复制
-p 保持原文件的属性信息
-q 静默模式
-P PORT 指明remote host的监听的端口

16.4.2 rsync 命令

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

16.4.3 sftp

交互式文件传输工具,用法和传统的ftp工具相似,利用ssh服务实现安全的文件上传和下载
使用ls cd mkdir rmdir pwd get put等指令,可用?或help获取帮助信息

sftp [user@]host
sftp> help

总结

玩到最后了,心足了吧。好好学,好好找工作,10K+只是起步,找不到10K+都别说是金鱼哥带出来的学生。

RHCSA认证作为基础认证,涉及的基础内容需要大家好好进行学习并巩固。有良好的基础才能更上一层楼。
好好加油,可以噶。


以上就是【金鱼哥】对 第十六章 文件查找、传输和打包压缩 的简述和讲解。希望能对看到此文章的小伙伴有所帮助。

红帽认证专栏系列:
RHCSA专栏:戏说 RHCSA 认证
RHCE专栏:戏说 RHCE 认证
此文章收录在RHCA专栏:RHCA 回忆录

如果这篇【文章】有帮助到你,希望可以给【金鱼哥】点个赞,创作不易,相比官方的陈述,我更喜欢用【通俗易懂】的文笔去讲解每一个知识点。

如果有对【运维技术】感兴趣,也欢迎关注❤️❤️❤️ 【金鱼哥】❤️❤️❤️,我将会给你带来巨大的【收获与惊喜】!

你可能感兴趣的:(戏说,RHCSA,认证,运维基本功,运维,linux,服务器,RHCSA)