服务器数据的安全性一直都是服务器日常管理的重中之重。Linux服务器虚拟化虽然以其高度可靠的作业系统而闻名,不过系统失效仍然可能发生。可能因为硬体故障,电源中断,或其他不可预料的问题。更常见的这 些问题是来自人为的错误,不当的变动,甚至因为删除重要的档案。
当服务器出现了问题而无法正常运转时,通过备份来还原服务器系统成为了代价最小的修复服务器错误的方法。于是,作为一个服务器管理人员,了解各种服务器备份的方案以及如何在各种情况下有选择性的实施备份方案变得尤为重要。
首先介绍服务器数据备份的三种方式:完全备份、差异备份以及增量备份
1、完全备份(Full Backup)
备份全部选中的文件夹,并不依赖文件的存档属性来确定备份那些文件。在备份过程中,任何现有的标记都被清除,每个文件都被标记为已备份。换言之,清除存档属性。
完全备份就是指对某一个时间点上的所有数据或应用进行的一个完全拷贝。实际应用中就是用一盘磁带对整个系统进行完全备份,包括其中的系统和所有数据。这种备份方式最大的好处就是只要用一盘磁带,就可以恢复丢失的数据。因此大大加快了系统或数据的恢复时间。然而它的不足之处在于,各个全备份磁带中的备份数据存在大量的重复信息;另外,由于每次需要备份的数据量相当大,因此备份所需时间较长。
2、差异备份(Differential Backup)
备份自上一次完全备份之后有变化的数据。差异备份过程中,只备份有标记的那些选中的文件和文件夹。它不清除标记,也即备份后不标记为已备份文件。换言之,不清除存档属性。
差异备份是指在一次全备份后到进行差异备份的这段时间内,对那些增加或者修改文件的备份。在进行恢复时,我们只需对第一次全备份和最后一次差异备份进行恢复。
3、增量备份 (Incremental Backup )
备份自上一次备份(包含完全备份、差异备份、增量备份)之后有变化的数据。增量备份过程中,只备份有标记的选中的文件和文件夹,它清除标记,既:备份后标记文件,换言之,清除存档属性。
增量备份是指在一次全备份或上一次增量备份后,以后每次的备份只需备份与前一次相比增加和者被修改的文件。这就意味着,第一次增量备份的对象是进行全备后所产生的增加和修改的文件;第二次增量备份的对象是进行第一次增量备份后所产生的增加和修改的文件,如此类推。
通过以上的概念我们能够发现,差异备份与增量备份的区别在于它们备份的参考点不同:前者的参考点是上一次完全备份、差异备份或增量备份,后者的参考点是上一次完全备份。
这里有两个方案供选择:
1、完全备份与差异备份结合(建议使用)
以每周数据备份计划为例,我们可以在星期一进行完全备份,在星期二至星期五进行差异备份。如果在星期五数据被破坏了,则你只需要还原星期一完全的备份和星期四的差异备份。这种策略备份数据需要较多的时间,但还原数据使用较少的时间。
2、完全备份与增量备份结合
以每周数据备份为例,在星期一进行完全备份,在星期二至星期五进行增量备份。如果在星期五数据被破坏了,则你需要还原星期一正常的备份和从星期二至星期五的所有增量备份。这种策略备份数据需要较少的时间,但还原数据使用较多的时间。
于是我们开始思考如何有选择性的备份数据。
服务器虚拟化通过将服务器物理资源抽象成逻辑资源,让一台服务器变成几台甚至上百台相互隔离的虚拟服务器,将CPU、内存、磁盘、I/O等硬件变成可以动态管理的“资源池”,从而提高资源的利用率,简化系统管理,实现服务器整合,让IT对业务的变化更具适应力,从而得到了更多的应用。
目前使用最多的服务器虚拟化供应商为VMware,VMware虚拟机提供了VMware data recovery这个插件来备份虚拟服务器,当然,也可以使用虚拟机的快照功能,来保存服务器的某一状态,从而在服务器发生问题时,能够还原恢复服务器状态。
还有一种方法,与机器本身是否虚拟化无关,而与系统有关。在Linux服务器中,可以使用"tar"命令来备份系统及数据。其实,"tar"命令就是一个压缩/解压缩的一个过程。
可以通过man命令或者--help来查看tar命令的说明:
这里提供一条备份根目录的通用指令,具体需要依照情况更改:
tar cvpzf backup.tgz / --exclude=/proc --exclude=/lost+found --exclude=/backup.tgz --exclude=/mnt --exclude=/sys
其中:
cvpzf 表示创建一个压缩文档,给其赋予保存权限,并且使用"gzip"方式来压缩。如果想用"Bzip"方式压缩,可以将"z"更换为"j":"cvpzf" --> "cvpjf"。
backup.tgz 表示在当前目录新建一个backup.tgz文件作为压缩载体
/ 表示备份目录为根目录 "/"
--exclude="xxx" 表示如果不想备份某一个文件或文件夹xxx,则可以用"--exclude='xxx' "来将该目录剔除备份目录
恢复的命令为:
tar xvpfz backup.tgz -C /
如果使用了"Bzip"方式备份,则命令为:
tar xvpfj backup.tar.bz2 -C /