使用tar方式备份和恢复系统
为了能够编译LFS(Linux From Scratch(LFS)),我尝试在U盘上安装Ubuntu但是尚未成功,所以改成先安装到笔记本的本地磁盘,然后再通过TAR方式备份恢复到U盘运行。
备份前准备
在备份系统前,最好先清空“垃圾箱”并删除所有不许要的文件和程序:
清理掉浏览器缓存,密码
清理掉邮件帐号
清理掉密码、私钥和私有文件
备份
cd /
tar -cvpzf backup.tar.gz --exclude=/backup.tar.gz --exclude=/home/huatai/Dropbox --one-file-system /参数解释:
c- 创建新的备份归档v- 详细模式,tar命令将在屏幕显示所有过程p- 保留归档文件的权限设置z- 使用gzip压缩f <filename>- 指定存储的备份文件名--exclude=/example/path备份中不包括指定的文件--one-file-system- 不包含其他文件系统中文件。如果你需要其他文件系统,例如独立的/home分区,或者也想包含/media挂载的扩展目录中文件,则要么单独备份这些文件,要么不使用这个参数。如果不使用这个参数,就需要使用--exclude=参数一一指定不包含的目录。这些不包含的目录有/proc,/sys,/mnt,/media,/run和/dev目录。
以下时手工设置不备份目录的方法,例如:
cd / # THIS CD IS IMPORTANT THE FOLLOWING LONG COMMAND IS RUN FROM /
tar -cvpzf backup.tar.gz \
--exclude=/backup.tar.gz \
--exclude=/proc \
--exclude=/tmp \
--exclude=/mnt \
--exclude=/dev \
--exclude=/sys \
--exclude=/run \
--exclude=/media \
--exclude=/var/log \
--exclude=/var/cache/apt/archives \
--exclude=/usr/src/linux-headers* \
--exclude=/home/*/.gvfs \
--exclude=/home/*/.cache \
--exclude=/home/*/.local/share/Trash /如果需要将备份文件分割成小文件:
tar -cvpz <put options here> / | split -d -b 3900m - /name/of/backup.tar.gz.通过网络备份
使用Netcat通过网络备份
netcat提供了非常方便的网络备份:
在接收服务器上:
nc -l 1024 > backup.tar.gz发送服务器上:
tar -cvpz <all those other options like above> / | nc -q 0 <receiving host> 1024使用SSH通过网络备份
tar -cvpz <all those other options like above> / | ssh <backuphost> "( cat > ssh_backup.tar.gz )"恢复
假设需要恢复的目录挂载在/media目录:
sudo tar -xvpzf /path/to/backup.tar.gz -C /media/whatever --numeric-ownerx告诉tar解压缩-C <directory>告知tar在解压缩文件之前先进入指定<directory>目录,这样就会恢复在这目录下。这里的案例是将文件恢复到/media/whatever目录,也就是挂载分区的目录--numeric-owner告诉tar恢复文件的owner帐号数字,而不是匹配用于恢复系统的用户名帐号。
恢复步骤
如果你能够通过live-cd启动主机,建议采用chroot方式进入恢复后的操作系统目录(这里假设
/media/sda5)
mount -t proc proc /media/sda5/proc
mount --rbind /sys /media/sda5/sys
mount --make-rslave /media/sda5/sys
mount --rbind /dev /media/sda5/dev
mount --make-rslave /media/sda5/dev
--make-rslave参数在后面安装的systemd支持所需
进入Ubuntu系统
chroot /media/sda5 /bin/bash
source /etc/profile
export PS1="(chroot) $PS1"(实际可忽略)恢复之后可能还需要恢复没有包含在
--one-file-system中的一些系统目录
cd /media/sda5
mkdir proc sys mnt media如果是在不同的主机上恢复系统,需要修改
/etc/fstab以及/boot/grub
例如/boot/grub/grub.cfg中所有原 root=UUID=3db306b6-2d5e-4e4c-8d22-4fe70ce0d0a4 需要修改成新的分区UUID root=
恢复GRUB
sudo -s
for f in dev dev/pts proc ; do mount --bind /$f /media/whatever/$f ; done
chroot /media/whatever
dpkg-reconfigure grub-pc遇到无法启动的问题则需要确保:
UEFI启动的分区必须是FAT32,独立分区(
/dev/sda1),并且挂载到/boot,这样才能够启动如果是多Linux操作系统启动,需要把多个操作系统到启动内核都复制到同一个
/boot分区设置内核启动参数中
root=PARTUUID=5e878358-02,应该使用的是分区UUID,这个分区UUID是parted划分分区时候创建的标记
详细参考我的实践
How to Repair, Restore, or Reinstall Grub 2 with a Ubuntu Live CD or USB提供了一个修复方法:
grub-install /dev/sdX
grub-install --recheck /dev/sdX
update-grub此外,在CentOS论坛有一篇multi boot with Ubuntu可以参考,方法是先安装CentOS,然后再安装Ubntu。最后在Ubuntu的/etc/grub.d/40_custom中添加CentOS内容
#!/bin/sh
exec tail -n +3 $0
# This file provides an easy way to add custom menu entries. Simply type the
# menu entries you want to add after this comment. Be careful not to change
# the 'exec tail' line above.
###
menuentry "Centos-5.4" {
set root=(hd0,[b]1[/b])
chainloader +1
}然后执行sudo update-grub或者sudo update-grub2就可以双启动。
从网络恢复
接收服务器
以下案例假设恢复到分区
/dev/sda5
确保接收服务器已经挂载磁盘/dev/sda5目录/media/sda5
mkdir /media/sda5
mount /dev/sda5 /media/sda5nc -l 1024 | sudo tar -xvpzf - -C /media/sda5这个命令中
-字符表示tar接收从标准输入而不是一个文件,这里的标准输入是从pipe管道
这里如果出现报错Ncat: socket: Address family not supported by protocol QUITTING.请检查一下服务器是否禁止了IPv6,默认情况下nc会尝试同时使用IPv4和IPv6。
发送服务器
cat backup.tar.gz | nc -q 0 <receiving host> 1024备份文件解压缩通过管道经
nc发送给远程服务器的1024端口
dd命令结合ssh
对于服务器磁盘完全一致(磁盘规格和分区都一致),则还可以通过 dd 命令来完成clone,并且通过SSH通道可以实现远程复制:
dd if=/dev/sda | ssh user@<receiving host> dd of=/dev/sda注意:上述
/dev/sda非系统磁盘
备份可以采用压缩方式
dd if=/dev/sda | gzip -1 - | ssh user@<receiving host> dd of=image.gz或者反向执行(从远程备份到本地)
ssh user@remote "dd if=/dev/sda | gzip -1 -" | dd of=image.gz参考
Last updated
Was this helpful?