网站也可以利用文件压缩的技术来进行数据传送,好让网站带宽的可利用率上升。 1 2 gzip压缩的文件可以被Windows下的WinRAR和7zip软件解压缩。 bzip2是为了代替gzip。bzip2的压缩比优于gzip。 xz在gzip和bzip2的基础上压缩比更优。但需要的时间也更长。 将多个文件或目录包成一个文件,就是打包。 参数详解: 备份/etc文件夹: 备份时的危险动作:-P 解压缩的目录选择: 仅解压缩单一文件的方法: 打包某个目录,除去其中的某些文件: 打包比某个文件要新的文件: 打包后,压不压缩,名称不同: 将文件打包到某些特殊设备: 利用管道命令与数据流: 系统备份范例: 常见问题: 光盘刻录工具:(这里暂时不学) 使用dd来备份,是笨拙的,但是dd只管拷贝整个扇区,并不管里面是啥,有啥拷啥。 cpio可以备份任何东西,但是它不会主动去找文件备份,需要配合find
第八章 文件与文件系统的压缩
8.1 压缩文件的用途与技术
将没有使用到的空间丢出来【0000 0001—->1】
将重复的数据进行统计记录【100个1】8.2 Linux系统常见的压缩命令
压缩文件扩展名
压缩技术
.Z
compress(少用)
.zip
zip(支持Windows常用的zip)
.gz
gzip(由GNU计划开发,应用最广)
.bz2
bzip2(压缩比更好)
.xz
xz(压缩比更好)
.tar
tar程序打包的文件,并未压缩过
.tar.gz
tar打包,gzip压缩
.tar.bz2
tar打包,bzip2压缩
.tar.xz
tar打包,xz压缩
gzip [-cdtv#] 文件名 -c 将压缩的数据输出到屏幕上,可以通过数据流重定向来处理 -d 解压缩的参数 -t 可以用来检验一个压缩文件的一致性,看看文件有无出错 -v 可以显示出源文件/压缩文件的压缩比等信息 -# 井号键代表数字,代表压缩等级,-1最快,但是压缩比最差;-9最慢但是压缩比最好,默认是-6 gzip -v 文件名 压缩文件,同时失去源文件,只剩压缩文件 zcat 文件名 查看压缩文本文件的信息 zmore zless都可以 gzip -d 文件名 解压缩,同时失去压缩文件,只剩源文件 gzip -9 -c filename > filename.gz 用最佳压缩比压缩,并保留源文件 zgrep -n 'keyword' filename.gz 找出压缩文件中关键字所在行
gzip被用来替代compress。bzip2 [-cdkzv#] 文件名 -c -d -v -# 和gzip的一样 -k 保留原始文件,不删原始文件 -z 压缩的参数(默认值,可以不加) bzip2 -v filename bzcat filename.bz2 bzip2 -d filename.bz2 bzip2 -9 -c filename > filename.bz2
对于大容量文件来说,bzip2压缩时间会比较久,比gzip久的多。xz [-dtlkc#] 文件名 -l 列出压缩文件的相关信息 其他同上 xz -v filename xz -l filename.xz 查看详细信息 xzcat filename.xz 读出压缩文件的内容 xz -d filename.xz 解压缩 xz -k filename 压缩时保留源文件
压缩性能3者对比: -rw-rw-r--. 1 dj dj 123932 5月 31 14:31 services.bz2 -rw-rw-r--. 1 dj dj 135489 5月 31 14:19 services.gz -rw-r--r--. 1 dj dj 99608 5月 31 14:14 services.xz 计算压缩时间: time gzip -c services > services.gz 快 time bzip2 -c services > services.bz2 中 time xz -c services > services.xz 慢
8.3 打包命令tar
tar [-z|-j|-J][cv][-f 待建立的新文件名] filename... 打包与压缩 tar [-z|-j|-J][tv][-f 既有的tar文件名] 查看文件名 tar [-z|-j|-J][xv][-f 既有的tar文件名][-C 目录] 解压缩 tar -jcv -f filename.tar.bz2 要被压缩的文件或目录名称 压缩 tar -jtv -f filename.tar.bz2; 查询 tar -jxv -f filename.tar.bz2 -C 欲解压缩的目录 解压缩
tar [-z|-j|-J][cv][-f 待建立的新文件名] filename... 打包与压缩 -z 通过gzip的支持进行压缩或解压缩,此时文件名最好是.tar.gz -j 通过bzip2的支持压缩或解压缩,此时文件名最好是.tar.bz2 -J 通过xz的支持压缩或解压缩,此时文件名最好是.tar.xz 以上,-z -j -J不能同时出现 cv 首先-c是建立打包文件,可搭配-v查看过程中被打包的文件名filename tar [-z|-j|-J][tv][-f 既有的tar文件名] 查看文件名 tv 查看打包文件的内容含有哪些文件名,重点在查看【文件名】 tar [-z|-j|-J][xv][-f 既有的tar文件名][-C 目录] 解压缩 xv 解包或是解压缩的功能,可以搭配-C在特定目录解压 -c -t -x 不能同时出现 -p 保留备份数据的原本权限与属性,常用语备份的重要配置文件 -P 保留绝对路径,即允许备份数据中含有根目录存在之意 --exclude=FILE 在压缩过程中,不要将FILE打包
这里使用小写的-p,防止恢复时旧资料覆盖当前新资料,哭死也找不回了su - time tar -zpcv -f /root/etc.tar.gz /etc 使用gzip,快 time tar -jpcv -f /root/etc.tar.bz2 /etc 使用bzip2,中 time tar -Jpcv -f /root/etc.tar.xz /etc 使用xz 慢 ll /root/etc* 出现: -rw-r--r--. 1 root root 12194747 5月 31 15:14 /root/etc.tar.gz -rw-r--r--. 1 root root 10492755 5月 31 15:15 /root/etc.tar.bz2 -rw-r--r--. 1 root root 8572040 5月 31 15:15 /root/etc.tar.xz du -sm /etc 查看实际目录占多少M 出现: 42 /etc 说明该文件夹实际占42M
tar -jtv -f /root/etc.tar.bz2 查询tar文件内部的文件列表 tar -jpPcv -f /root/etc.and.root.ar.bz2 /etc 将文件名中的(根)目录也备份下来,恢复时极为危险!!!!!慎用大P,防止旧资料覆盖新资料
tar -jxv -f /root/etc.tar.bz2 在本目录解压缩 tar -jxv -f /root/etc.tar.bz2 -C /tmp 在/tmp目录解压缩
tar -jtv -f /root/etc.tar.bz2 | grep 'shadow' 这个grep在截取关键词,找到你要解压缩的那个文件名 tar -jxv -f 打包文件.tar.bz2 待解压缩文件名 这是解压缩单一文件的语法 tar -jxv -f /root/etc.tar.bz2 etc/shadow 好了,开始解压缩了
备份/etc和/root两个文件夹(不含/root/etc*),备份后的文件放置在/root下,所以还要把自身排除在外tar -jcv -f /root/system.tar.bz2 --exclude=/root/etc* --exclude=/root/system.tar.bz2 /etc /root
find /etc -newer /etc/passwd 打包/etc中比/etc/passwd还要新的文件 tar -jcv -f /root/etc.newer.then.passwd.tar.bz2 --newer-mtime="2020/04/29" /etc/* tar -jtv -f /root/etc.newer.then.passwd.tar.bz2 | grep -v '/$' 显示出文件,调用出结尾非/的文件名
tarfile (只是一个称呼) tar -cv -f file.tar tarball (只是一个称呼) tar -jcv -f file.tar.bz2
tar -cv -f /dev/st0 /home /root /etc 把/home /root /etc共3个文件夹备份到/dev/st0磁带设备中
cd /tmp tar -cvf - /etc | tar -xvf - 将/etc整个目录一边打包,一边在/tmp打开
mkdir /backups 全都备份到backups文件夹 chmod 700 /backups 只能root用户进入操作,其他人均不得见 ll -d /backups 出现: drwx------. 2 root root 6 5月 31 16:04 /backups 开始备份,/home/loop*不需要备份,/root下的压缩文件不需备份 tar -jcv -f /backups/backup-system-20200531.tar.bz2 --exclude=/root/*.bz2 --exclude=/root/*.gz --exclude=/home/loop* /etc /home /var/spool/mail /var/spool/cron /root ll -h /backups/ 出现: 总用量 20M -rw-r--r--. 1 root root 20M 5月 31 16:09 backup-system-20200531.tar.bz2
解压缩后的SELinux问题:
如果你的系统必须要以备份的数据来恢复到原本的系统中,恢复完成后,死活登录不上去,说明/etc/shadow这个密码文件的SELinux类型在还原时被更改了,导致系统的登录程序无法顺利读取它,才造成无法登录的窘境,解决方法共3种:
(1)通过各种可行的恢复方式登录系统,修改/etc/selinux/config文件,将SELinux改成permissive模式,重新启动后系统就正常了。
(2)第一次恢复系统后,不要立刻重新启动,先用restorecon -Rv /etc
自动修复一下SELinux的类型即可(鸟哥他推荐的)
(3)通过各种可行的方式登录系统,建立/.autorelabel文件,重新启动后系统会自动修复SELinux的类型,并且又会再次重新启动,之后就正常了8.4 XFS文件系统的备份与还原
xfsdump [-L S_label] [-M M_label] [-l #] [-f 备份文件] 待备份数据 -l 指定备份等级,0-9,默认0,即完整备份 -f 类似tar,后面接产生的文件 xfsdump -I 列出目前备份的信息状态 首次备份:将完整备份的文件名记录成为/srv/boot.dump xfsdump -l 0 -L boot_all -M boot_all -f /srv/boot.dump /boot 增量备份: xfsdump -I dd if=/dev/zero of=/boot/testign.img bs=1M count=10 随便建立一个10M的文件 xfsdump -l 1 -L boot_2 -M boot_2 -f /srv/boot.dump1 /boot 增量备份 ll /srv/boot.dump* xfsdump -I
xfsrestore -I 可以用来查看备份文件 xfsrestore [-f 备份文件] [-L S_label][-s] 待恢复目录 可以完成单一文件全系统恢复 xfsrestore [-f 备份文件] -r 待恢复目录 通过增量备份文件来恢复系统 xfsrestore [-f 备份文件] -i 待恢复目录 进入交互模式 xfsrestore -f /srv/boot.dump -L boot_all /boot 直接将数据覆盖回去 xfsrestore -f /srv/boot.dump -L boot_all /tmp/boot 将备份数据在/tmp/boot下面解开 du -sm /boot /tmp/boot 出现: 161 /boot 151 /tmp/boot diff -r /boot /tmp/boot 进行差异性查找 出现: 只在 /boot 存在:testign.img 只恢复grub2到/tmp/boot2中: xfsrestore -f /srv/boot.dump -L boot_all -s grub2 /tmp/boot2 恢复增量备份数据: xfsrestore -f /srv/boot.dump1 /tmp/boot 仅还原部分文件,交互模式: xfsrestore -f /srv/boot.dump -i /tmp/boot3
8.5 光盘写入工具
1、制作一般数据光盘镜像文件 mkisofs [-o 镜像文件] [-Jrv] [-V vol] [-m file] 待备份文件 -graft-point isodir=systemdir 镜像备份3个文件夹到一个镜像文件中,等号左侧是镜像文件中的目录,右侧是实际目录 mkisofs -r -V 'linux_file' -o /tmp/system.img -m /root/etc -graft-point /root=/root /home=/home /etc=/etc ll -h /tmp/system.img 出现: -rw-r--r--. 1 root root 104M 5月 31 17:09 /tmp/system.img 挂载一下,查看内容,然后再卸载: mount -o loop /tmp/system.img /mnt ll /mnt umount /mnt 可以先把所有要刻录的文件,放在一个文件夹/srv/cdrom内,进入这个文件夹,执行: mkisofs r -v -o /tmp/system.img . 把当前目录刻录进去
制作/修改可启动光盘镜像文件 下载镜像文件 把镜像文件放在/home目录 为了修改里面的数据: isoinfo -d -i /home/CentOS-7-x86_64-Minimal-2003.iso 先看看里面是啥 mount /home/CentOS-7-x86_64-Minimal-2003.iso /mnt 挂载到/mnt mkdir /srv/newcd rsync -a /mnt/ /srv/newcd 完整拷贝所有的权限属性等数据到/srv/newcd ll /srv/newcd 修改里面的数据 为了建立iso文件: ll /srv/newcd/isolinux/ cd /srv/newcd mkisofs -o /custom.iso -b isolinux/isoLinux/bin -c isolinux/boot.cat -no-emul-boot -V 'CentOS 7 x86_4' -boot-load-size 4 -boot-into-table -R -J -v -T . 这里最后有个点莫忘了 此时就有个/custom.img文件存在,可以将该光盘刻录出来
cdrecord 新的系统改成了 wodim wodim --devices dev=/dev/sr0... 查询刻录机的bus位置 wodim -v dev=/dev/sr0 blank=[fast|all] 抹除重复读写盘 wodim -v dev=/dev/sr0 -format 格式化DVD+RW wodim -v dev=/dev/sr0 [可用选项功能] file.iso
8.6 其他常见的压缩与备份工具
dd if="input_file" of="output_file" bs="block_size" count="number" dd if=/etc/passwd of=/tmp/passwd.back 把/etc/passwd备份到/tmp/passwd.back dd if=/dev/sr0 of=/tmp/system.iso 将刚刚刻录的光盘的内容,再次备份下来成为镜像文件 dd if=/tmp/system.iso of=/dev/sda 假设/dev/sda是你的U盘,将iso文件刻录到U盘,可以用U盘来安装Linux dd if=/dev/vda2 of=/tmp/vda2.img 将整个/boot文件系统备份下来
cpio -ovcB > [file|device] 备份 cpio -ivcdu > [file|device] 还原 cpio -ivct > [file|device] 查看 找出/boot下面的所有文件,然后将它备份到/tmp/boot.cpio cd / find boot -print find boot | cpio -ocvB > /tmp/boot.cpio ll -h /tmp/boot.cpio file /tmp/boot.cpio 将刚刚的文件在/root目录下解压缩: cd ~ cpio -idvc < /tmp/boot.cpio ll /root/boot /boot
本网页所有视频内容由 imoviebox边看边下-网页视频下载, iurlBox网页地址收藏管理器 下载并得到。
ImovieBox网页视频下载器 下载地址: ImovieBox网页视频下载器-最新版本下载
本文章由: imapbox邮箱云存储,邮箱网盘,ImageBox 图片批量下载器,网页图片批量下载专家,网页图片批量下载器,获取到文章图片,imoviebox网页视频批量下载器,下载视频内容,为您提供.
阅读和此文章类似的: 全球云计算